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METHOD AND APPARATUS FOR COMPUTING 



VECTOR ABSOLUTE DIFFERENCES 
FIELD OF THE INVENTION 

[0001] The invention relates to data processing systems using vector processing 
and Very Long Instruction Word (VLIW) architecture, more particularly to 
computing vector absolute differences. 
BACKGROUND OF THE INVENTION 

[0002] Figure 3 shows a typical computer system having at least one host processor 
1301 and host memory 1302. The system core logic chip 1300, also known as a 
memory controller or a north bridge, facilitates data transfer between the host 
memory 1302 through a memory interface 1304, the host processor 1301 through a 
host interface 1303, graphics controller 1308 through a PCI-0/AGP interface 1306 
and other peripherals such as input/output (I/O) controller 1309 through PCI-1 
interface 1307. An IEEE-1394 bus 1310, also known as a FireWire bus, may be 
coupled to the I/O controller 1309. The FireWire bus 1310, in some applications, 
may be directly coupled to the system core logic chip 1300 through the PCI-1 
interface 1307. The FireWire bus 1310 provides interfaces to other FireWire 
devices, such as FireWire storage devices (e.g., FireWire hard disks). Other 
components such as universal serial bus (USB), Ethernet device, etc., may be 
coupled to the system core logic 1300. Due to these interfaces, the system core logic 
1300 requires a large number of pins. On the other hand, the logic required for the 
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system core logic functions is relatively small. The large number of interface pins 
causes the area of the system core logic 1300 to become quite large. The small 
amount of logic combined with continuing advancement in silicon technology, 
results in the significant portion of that area being unused. 
[0003] The concept of a media processor has been around for a while. A media 
processor typically refers to an engine designed for the processing of a combination 
of audio, video and graphics data. A media processor can also be used for other 
tasks that require similar processing features. The media processors have so far been 
designed as stand-alone processors and have enjoyed moderate success in processing 
video data. The media processors can be used in add-in boards to perform various 
tasks. Figure 4A shows an example of a conventional media processor in a 
computer system. The system 1400 of Figure 4A includes a host processor or 
processors 1401, host memory 1402, a graphics controller 1404, and a media 
processor 1405. The bus 1403 interconnects these various components together. 
Other peripherals may be connected to the bus 1403. 

[0004] Figure 5A shows an example of a conventional media processor. The media 
processor 1500 includes an input/output (I/O) interface, which receives and transmits 
data between the media processor and other components of the system, such as host 
processor and host memory 1506. The media processor 1500 may also include a 
cache memory 1504 for temporarily storing data before the instruction decoder 1502 
decodes the instructions and transmits them to different functional units, such as 
vector processors 1503. The media processor 1500 may include one or more register 
files for storing input or output data of the functional execution units 1503. 
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[0005] A media processor may employ multiple functional units (e.g., adder, 
multiplier, shift, load/store units), and use very long instruction word (VLIW) 
programming. Depending on the target application, the media processor may have a 
combination of functional units of different kind and there may be more or fewer of 
these units. Some media processors only integrate vector-processing units (e.g., 
vector processors). Vector processors allow execution of a single instruction on 
multiple data elements. There are several vector processors available on the market 
(e.g., Motorola's AltiVec, SSE-2, etc.). The conventional media processors use the 
scalar processing unit available through the host processors. Thus, the vector data 
are processed by the vector processing units and the scalar data are processed by the 
scalar processing units through the host system. This arrangement may require the 
data to be transferred between the host system and the media processor, thus it may 
impact performance. 

[0006] The conventional media processor may use very long instruction word 
(VLIW) programming. Depending on the target application, the media processor 
may have a combination of functional units of different kind and there may be more 
or few of the functional units. The VLIW contains one instruction slot for each of 
these units. The VLIW programming is based on issuing instructions to all of these 
functional units in the same clock cycle of the host processor. Not all instructions 
may need to be issued on each clock cycle. If an instruction slot in the VLIW 
instruction is not used in a particular cycle, it is assigned a code of no-operation 
(NOOP), but it still occupies bits in the VLIW instruction. This results in code 



04860.P2687 



4 



expansion and therefore in memory, bandwidth, and instruction cache related 
inefficiencies. 

[0007] Typically, a graphics controller may be coupled to the PCI bus. PCI bus 
supports multiple peripheral components and add-in cards at a peak bandwidth of 
132 megabytes per second. Thus, PCI is capable of supporting full motion video 
playback at 30 frames per second, true color high-resolution graphics and 100 
megabytes per second Ethernet local area networks. However, the emergence of 
high-bandwidth applications, such as three-dimensional (3-D) graphics applications, 
threatens to overload the PCI bus. As a result, a dedicated graphics bus slot, known 
as an accelerated graphics port (AGP), has been designed and integrated into the 
computer system, such as AGP interface 1306 of Figure 3. AGP operates at higher 
frequency and transfers data at a rate up to 1 GB/sec. AGP's greater bandwidth will 
allow game and 3D application developers to store and retrieve larger, more realistic 
textures in system memory rather than video memory, without incurring a dramatic 
performance hit to the rest of the system. 

[0008] Many computer systems, such as system 1300 of Figure 3, use virtual 
memory systems to permit the host processor 1301 to address more memory than is 
physically present in the main memory 1302. A virtual memory system allows 
addressing of very large amounts of memory as though all of that memory were a 
part of the main memory of the computer system. A virtual memory system allows 
this even though actual main memory may consist of some substantially lesser 
amount of storage space than is addressable. 
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[0009] As a result, a system with a graphics accelerator connected to the AGP port 
of the system core logic normally requires graphics address re-mapping table 
(GART) to translate a virtual address space to the physical address. However, since 
the AGP address ranges are designed dedicated to the AGP accelerator, it is a fixed 
memory range that may not be shared with other components in the system. 
[0010] In addition, the media processor in an AGP system normally uses mapped 
non-coherent memory access. Non-coherent memory operations are those operations 
where data goes directly to and from memory and is returned directly back to the 
media processor and never goes through the processor cache. On the other hand, a 
coherent memory system always goes through the host processor. The data of a 
coherent memory system may exist in the host processor's cache or in the host 
memory. Referring to Figure 3, when a coherent memory access request is issued, 
the host processor 1301 checks whether the host processor's cache (not shown) 
contains newer data than the host memory 1302. If the host processor cache contains 
newer data, the host processor 1301 flushes its caches into the host memory 1302 
before the data is read from the host memory. Lack of coherent access of the 
conventional approaches posts an inconvenience to the applications. 
[0011] As graphics data processing is getting more complex, improvements in media 
data processing systems increase the ability to handle more complex processing. 
[0012] Many applications, such as motion estimation for video images 
compressed in Motion Picture Expert Group (MPEG) standard, curve fitting, and 
others, require the computation of the sum of absolute difference of two vectors of 
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numbers in order to determine a measurement of the distance (or difference) between 
the two vectors. If vector vA contains elements 

{vAO, vAl, vAn} , 

and vector vB contains elements 

{vBO, vBl, . . . , vBn} , 

the absolute difference |vA-vB| contains elements 

{ [ vAO-vBO | , | vAl-vBl | , . . . , | vAn-vBn | } . 
The sum of absolute difference of vA and vB is 
|vA0-vB0|+|vAl-vBl|+ ... +|vAn-vBn|. 

[0013] In one method according to the prior art, an instruction for vector 
maximum (Vec_max), an instruction for vector minimum (Vec_min), and an 
instruction for vector subtract (Vec_sub) are required to compute the absolute 
difference of two vectors using a vector processor. For example, the following 
sequence of instructions may be used to compute the absolute difference between 
vectors vA and vB. 

Ve c_jmax ( vMax , vA , vB ) 
Vec_min(vMin / vA, vB) 
Vec_sub(vResult, vMax, vMin) 
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[0014] In the above instructions, Vec^max selects the larger ones from the 
elements of vector vA and the corresponding elements of vector vB to produce 
vector vMax; on the other hand, Vec_min selects the smaller ones from the elements 
of vA and the corresponding elements of vB to produce vector vMin; and Vec_sub 
subtracts vMin from vMax to produce vector vResult, which is the absolute 
difference of vectors vA and vB. Such a method takes two vector registers for the 
storage of intermediate results and three instructions to obtain the absolute difference 
of two vectors of numbers. 

[0015] In another method according to the prior art, the following sequence of 
instructions is used to compute the absolute difference between vectors vA and vB. 

Ve c_sub ( vTemp 0 , vA , vB ) 
Vec_sub ( vTempl , 0 , vTempO ) 
Vec_max (vResult, vTempO, vTempl) 

[0016] In the above instructions, Vec_sub first produces vector vTemp0=vA-vB, 
then, vector vTempl=vB-vA; and Vec_max selects the positive ones from the 
elements of vTemp0=vA-vB and the corresponding elements of vTempl=vB-vA to 
produce vector vResult, which is the absolute difference of vectors vA and vB. Such 
a method also takes two vector registers for the storage of intermediate results and 
three instructions to obtain the absolute difference of two vectors of numbers. 
[0017] Since many applications, such as application programs for performing 
motion estimation and motion compensation in decoding video images encoded 
using an MPEG standard, require the computation of the sum of absolute difference 
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of two vectors, it is desirable to have an efficient method to compute the absolute 
difference of two vectors. 

[0018] Vector processors allow simultaneous processing of a vector of data 
elements using a single instruction. Table look-up for a vector of data elements maps 
the data elements of the vector into another vector of data elements using one or an 
array of tables. In one scenario, each data elements of a vector is looked up from a 
look-up table, and looking up the data element from the look-up table is independent 
of looking up other elements from other look-up tables and thus multiple look-ups 
are preformed sequentially over time. 

[0019] In one embodiment of the prior art, a vector permutation instruction in a 
vector processor is used to implement table look-up for a vector of data elements. 
The instruction for vector permutation generates a new vector of data, vD, selected 
from two vectors of elements, vA and vB, according to a vector of index data, vl. 
For example, AltiVec, a vector processor by Motorola, implements vector 
permutation instruction Vec_perm. When executing 

Vec_perm(vD, vA, vB, vl) 

the vector processing unit receives vectors vA, vB, and vl from a vector register file 
and produces vector vD. Vectors vA and vB are vectors of 16 data elements. Vectors 
vl is a vector of 16 integer numbers, containing control information to select 16 
numbers from the 32 numbers in vectors vA and vB into vector vD. Each of the 16 
integer numbers is encoded with i) information determining whether to select entries 
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from either vA or vB, and ii) information determining the index for selecting a 
particular entry from a vector (vA or vB). 

[0020] While this approach can be used to perform table look-up for a vector of 
data from a single small look-up table, there are severe limitations in its practical 
applications in processing large look-up tables. The indices for the look-up tables 
must be preprocessed to generate the index information in vector vl. The size of the 
look-up table that can be used in a table look-up in a single instruction is restricted 
by the number of bits allocated to represent the index information in vector vl, and 
by the total number of data elements that can be held by vector registers vA and vB. 
In a typical vector processor, two vector registers (vA and vB) can hold only 32 8-bit 
data elements. In general, it is necessary to use a program of multiple sequential 
instructions to implement vector look-up using one or an array of look-up tables. 
Further, due to the limited size of a vector register file, only a part of look-up table 
entries may be loaded into the vector register file when large look-up tables are used. 
Thus, when a set of large look-up tables are used, table look-up for a vector of data 
elements requires repeatedly loading table entries into the vector register file. Thus, 
it can be a very inefficient operation. 

[0021] There are hardware implementations for table look-up. For example, 
most display hardware incorporates table look-up functionalities for gamma 
correction of displayed images. However, such functionality is very limited; and 
such hardware cannot be used to perform general purpose table look-up for a vector 
of data elements from an array of look-up tables. 
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[0022] Since many applications, such as software programs for computing pixel 
values in image processing, require the mapping of a set of values to another set of 
values using a set of different tables, it is desirable to have an efficient method to 
perform table look-up for a vector of data elements. 

[0023] Variable length coding is a coding technique often used for lossless data 
compression. Codes of shorter lengths are assigned to frequently occurring fixed- 
length data to achieve data compression. Variable length encoding is widely used in 
compression of video data. For example, video images in accordance with JPEG, 
MPEG or DV standards are compressed using variable length encoding. 
[0024] Variable length code words used in JPEG, MPEG, or DV compression 
schemes are typically from 2 to 16 bits in length. Thus, a single look-up table with 
16-bit indices has potentially 64K entries. However, the majority of the 64K entries 
are redundant entries. 

[0025] In one prior art embodiment, small look-up tables are arranged in a 
branched tree data structure with pointer logic to track the decoded value during 
decoding. A series of look-up operations using a number of small tables, typically, as 
many as four separate tables, are necessary in order to decode a code word. 
[0026] To reduce the number of look-up operations and associated overhead, U.S. 
Patent No. 6,219,457, incorporated by reference herein, describes a method for 
variable length decoding using only two look-up tables. A code word is first 
preprocessed to generate an index for a first look-up table to look up an entry for the 
generation of a pointer for a variable length code table. The entry looked up from the 
variable length table, using the pointer obtained from the first look-up table, 
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provides information necessary to decode the code word. However, two sequential 
look-up operations, as well as associated overhead for preprocessing, are necessary 
to decode a code word. 

[0027] Matrix transposition is a linear algebra operation commonly used in many 
fields of applications, such as in signal and image processing. The software 
implementations of matrix transposition are computationally expensive. When 
implemented on a scalar CPU, matrix transposition is performed by reading the 
elements of a matrix one element at a time and storing them in a transposed order. 
[0028] The amount of computation can be greatly reduced by utilizing vector 
processing units. The efficiency of vector processing depends on the vector width 
and the flexibility of the instruction set supported by the execution units. One 
efficient method for matrix transposition on a vector processor (e.g., AltiVec by 
Motorola with vectors of 128-bit width) uses a series of vector merge instructions. 
An vector merge instruction interleaves halves of the elements from two vector 
registers to generate a new vector. Similarly, U.S. Patent No. 5,875,355 describes 
methods to transpose a matrix using various data restructuring instructions. 
[0029] U.S. Patent No. 6,021,420 describes a matrix transposition device using a 
plurality of storage devices which is arranged so as to be able to input and output 
column vectors in parallel. However, the device described in U.S. Patent No. 
6,021,420 is specialized for matrix transposition and is difficult to be adapted for 
other applications. 

[0030] An image can be represented by a matrix of points referred to as pixels. Each 
pixel has an associated color. Typically, a color may be represented by three 
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components. The three different components used to represent the color define a 
color space. Many color spaces are presently used in various applications. For 
example, in computer graphics colors are represented in a RGB color space, where a 
color is represented by the levels of Red (R), Green (G), and Blue (B). In television 
equipment, colors are presented in a YUV space, where a color is represented by the 
levels of intensity (Y) and color differences (U and V). A YCrCb color space is a 
scaled and offset version of the YUV color space color, where the Y component 
represents luminance (intensity or picture brightness), the Cb component represents 
the scaled difference between the blue value and the luminance (Y), and the Cr 
component represents the scaled difference between the red value and the luminance 
(Y). Since digitized YCrCb components occupy less bandwidth when compared to 
digitized RGB (Red-Green-Blue) components, compressed video signals (e.g., DV 
signals) represent colors in a YCrCb space. The YCrCb color space was developed 
as part of a world-wide digital component video standard. However, many imaging 
and displaying devices generally use colors in a RGB space. Thus, a multimedia 
system must convert a video image from a YCrCb color space to a computer image 
in a RGB color space. Other commonly used color spaces include HLS, HSI, and 
HSV. Therefore, it is necessary to convert colors represented in one color space into 
colors represented in another color space for a set of pixels in an image. For a video 
stream, it is necessary to convert the color components for each frame of images in 
the video stream. 

[0031] There are many techniques for color space conversion. For example, U.S. 
Patent No. 5,510,852 describes a method and apparatus for performing color space 
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conversion between digitized YCrCb components and digitized RGB components 
using a color look up table unit which is provided with transformation component 
values based on a selected one of two sets of conversions. A plurality of adders are 
coupled to the lookup table unit so as to receive the outputs thereof and generate 
individual color components of converted space by adding the transformation 
component values corresponding to each of the individual color components of 
converted space relative to the color components of original space. However, since 
dedicated hardware is required to perform color space conversion according to U.S. 
Patent No. 5,510,852, such an approach is generally costly and is difficult to adapt to 
different configurations. 

[0032] Blending two images into a new image is a common operation in many 
applications. For example, a video editing application may blend the images from 
two different video streams to create a new video stream with special effects. The 
general blending equation for computing an attribute of a pixel in a new image using 
those in two source images can be written as: 

D = Kl * SI + K2 * S2 

[0033] where D is the resulting attribute of the pixel; SI and S2 are the attributes of 
the pixel in the source images; and Kl and K2 are the blending factors for the 
corresponding source images. 

[0034] The blending factors may be constants, but are more generally functions of 
alphal and/or alpha2. In the most common case, Kl equals alphal and K2 equals 
one minus alphal. The alpha values, known as "alpha" in the graphics world and 
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"key" in the video world, generally represent the desired opacity of the associated 
image pixel. Generally, the alpha value is not constant over an entire image. 
[0035] Blending is generally implemented using 32 bit, IEEE 754 compliant floating 
point arithmetic to avoid visually distracting artifacts. However, video source data, 
including "key", is usually supplied in 8 or 10 bit integer format for each attribute; 
hence it is normally required to convert the integer source data to floating point data 
before applying the general blend equation and then convert the result back to 
integer data post blending. 

[0036] To edit video streams, a video editing software application may be required 
to decode in real time several video streams in order to create video effects, such as 
blending of video sequences, picture in picture, titling, etc. The resulting 
uncompressed video images obtained after editing need to be compressed for 
storage. Compression/decompression of video data is an expensive operation. Add- 
in-boards are frequently used to accelerate the process of compressing or 
decompressing video data. Since such add-in-boards are quite expensive, video 
editing so far has been in the domain for video professionals. Consumer video 
editing software applications implemented on general purpose processors are slow 
and suffer from poor quality due to massive computation requirements. 
[0037] The DV format, such as DV25 or DV50, due to its linear nature (i.e., the 
consecutive frames of video data are encoded in their display order), relatively low 
information loss (by using high bit rate coding) and the constant bit rate (i.e., each 
compressed frame has a constant size) is a preferred format for video editing on the 
desktop computers. Most of the digital video cameras produce DV bit streams. The 
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compression and decompression processes of DV video streams are briefly outlined 
below. 

[0038] DV compression belongs to a family of constant bit rate block based 
transform coding techniques. The input to a DV encoder is a 29.97 frames per 
second digital video stream in YUV color space. DV standards support various 
sampling structures in YUV color space, such as 4:1:1, 4:2:0 and 4:2:2 image 
sampling structures. An input video stream is processed in the units of 8x8 two- 
dimensional blocks of pixels. Blocks are organized into macro blocks, each 
consisting of four or six 8x8 pixel blocks. Macro blocks are organized into 
segments. A segment comprises 5 macro blocks (e.g., 30 blocks) and is compressed 
into a constant 400-byte bit stream. 

[0039] Following the traditional transform coding approach, each pixel block is 
transformed into frequency domain using Forward Discrete Cosine Transformation 
(FDCT). The transformed coefficients are further quantized and entropy coded with 
variable length code words. Each compressed macro block in a segment has a header 
and a number of fixed size blocks (e.g., 4 luminance blocks and 2 chrominance 
blocks). In a segment, the code words for each block are concatenated before being 
distributed into the corresponding compressed-data area for the block in pass 1. In 
pass 2, the remaining of the blocks after the pass 1 operation that cannot be fitted 
into the corresponding compressed-data area are distributed in to their corresponding 
compressed macro block. In pass 3, the remainder after the pass 2 operation are 
distributed into the video segment. 
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[0040] The decompression process creates pixel data from a DV bit stream by 
performing reverse operations, namely Variable Length Decoding (VLD), Inverse 
Scaling (IS) and Inverse Discrete Cosine Transform (IDCT). Since code words are 
distributed in a segment in 3 passes, three corresponding passes of VLD operations 
can be used to recover all the information encoded using variable length code words. 
[0041] The documentation of standards IEC 61834 and SMPTE 314M contains 
detailed descriptions about DV standards. Other video standards and image formats, 
such as MPEG and JPEG, also involves discrete cosine transformation, quantization, 
and variable length decoding. The general procedure to compress and decompress 
such video streams or images are the same. 

[0042] Various implementations of DV decoders currently exist in the industry. 
Some dedicated chipsets are used in hardware implementations; and there are 
software applications for general purpose processors. The drawbacks of the 
hardware implementations using dedicated chipsets are the high cost, lack of 
scalability, and lack of compatibility with other components in video systems. The 
drawback of the software decoders on the general purpose CPUs is that the 
performance of a decoder highly depends on the computing environment, such as the 
run time usages of the CPU, memory, cache, and I/O devices. The instruction sets of 
general purpose processors are not well suited for processing encoded bit streams. 
[0043] Variable Length Decoding (VLD), when implemented on a general purpose 
processor, is limited in performance by the operations for table look-up and 
conditional branch. The Huffman code used in a DV video stream can be up to 16 
bits in length. One of the most efficient methods to perform VLD on a general 
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purpose processor is to use a single look-up table. However, the single look-up table 
contains 64K entries, each entry consisting of a triplet of {run, level, code length}. 
Since each entry stored in system memory may require 16 bits, the single look-up 
table may require 128 Kbytes of system memory. The look-up table may be resident 
in the system memory. A single look-up table approach is highly inefficient from 
caching point of view. The cache miss penalty can dramatically reduce the 
performance. Multi-table approaches reduce the amount of memory required by the 
look-up table by looking-up sequentially in a number of smaller look-up tables, and 
thus suffers from increased execution time due to multiple sequential look-up 
operations and associated overheads. 

[0044] The video editing applications require decoding several video streams 
simultaneously. Further, with High Definition TV (HDTV), the amount of 
processing power required for decompression can be very high. Thus, it is desirable 
to have efficient methods and apparatuses for variable length decoding bit streams. 
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SUMMARY OF THE INVENTION 

[0045] Methods and apparatuses for computing vector absolute differences are 
described here. 

[0046] In one aspect of the invention, a method for execution by a 
microprocessor in response to receiving a single instruction includes: receiving a 
first plurality of numbers and a second plurality of numbers; and generating 
substantially simultaneously a third plurality of numbers, each of which is an 
absolute difference between a number in the first plurality of numbers and a number 
in the second plurality of numbers. The above operations are performed in response 
to the microprocessor receiving the single instruction. 
[0047] The present invention includes apparatuses which perform these 
methods, including data processing systems which perform these methods and 
computer readable media which when executed on data processing systems cause the 
systems to perform these methods. 

[0048] Other features of the present invention will be apparent from the 
accompanying drawings and from the detailed description which follows. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



[0049] The present invention is illustrated by way of example and not limitation in 
the figures of the accompanying drawings in which like references indicate similar 
elements. 

[0050] Figure 1 shows a configuration of a computer system, which may be used by 
the present invention. 

[0051] Figure 2 shows another configuration of a computer system, which may be 

used by the present invention. 

[0052] Figure 3 shows a typical computer system. 

[0053] Figure 4A shows a media processor used in a compute system. 

[0054] Figure 4B shows an embodiment of the present invention. 

[0055] Figure 5A shows a conventional media processor. 

[0056] Figure 5B shows another embodiment of the present invention. 

[0057] Figure 6 shows another method for memory access used in one embodiment 

of the present invention. 

[0058] Figure 7 shows one embodiment of memory controller used in an 
embodiment of the present invention. 

[0059] Figure 8 shows an embodiment of memory interfaces used in the present 
invention. 

[0060] Figure 9 shows an example of an entry in one embodiment of the memory 
address re-mapping table of the present invention. 
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[0061] Figure 10A shows another example of an entry in one embodiment of the 
memory address re-mapping table of the present invention. 
[0062] Figure 10B shows an example of a PCI-0 mask register used in one 
embodiment of the present invention. 

[0063] Figure 11 shows a configuration of a memory mapping used in one 
embodiment of the present invention. 

[0064] Figure 12 shows an embodiment of a method accessing the memory address 
re-mapping table. 

[0065] Figure 13 shows another embodiment of a method accessing the memory 
address re-mapping table. 

[0066] Figure 14 shows yet another embodiment of a method accessing the memory 
address re-mapping table. 

[0067] Figure 15 shows yet another aspect of an embodiment of a method accessing 
the memory address re-mapping table. 

[0068] Figure 16 shows yet another aspect of an embodiment of a method accessing 
the memory address re-mapping table. 

[0069] Figure 17 shows an example of a compute engine used in one embodiment 
of the present invention. 

[0070] Figure 18 shows another embodiment of a compute engine used in the 
present invention. 

[0071] Figure 19A shows an embodiment of an instruction unit of a compute engine 
used in the present invention. 
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[0072] Figure 19B shows another embodiment of an instruction unit of a compute 
engine used in the present invention. 

[0073] Figure 20A shows a method accessing a command queue used in one 
embodiment of the present invention. 

[0074] Figure 20B shows another method accessing a command queue used in one 
embodiment of the present invention. 

[0075] Figure 21 shows an embodiment of a configuration of a command queue 
used in the present invention. 

[0076] Figure 22 shows an example of a command queue entry of the present 
invention. 

[0077] Figure 23 shows an example of the instruction priorities used in one 
embodiment of the present invention. 

[0078] Figure 24 shows an embodiment of dispatching instructions of the present 
invention. 

[0079] Figure 25 shows another embodiment of dispatching instructions of the 
present invention. 

[0080] Figure 26 shows an example of latency of instructions used in the present 
invention. 

[0081] Figure 27 shows yet another embodiment of dispatching instructions of the 
present invention. 

[0082] Figure 28 shows yet another embodiment of dispatching instructions of the 
present invention. 
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[0083] Figure 29 shows an example of the interrupt control registers of the 
invention. 

[0084] Figure 30 shows another example of the interrupt control registers of the 
invention. 

[0085] Figure 31 shows a flow diagram illustrating the general steps used by a 
processor to manipulate data in executing an instruction according to one 
embodiment of the invention. 

[0086] Figure 32 illustrates a block diagram representation of a circuit for the 
execution of a method to compute an absolute difference of two vectors of numbers 
according to one embodiment of the present invention. 

[0087] Figure 33 illustrates a block diagram representation of a circuit for the 
execution of a method to compute an absolute difference of two numbers according 
to one embodiment of the present invention. 

[0088] Figure 34 illustrates data representations for the execution of an 
instruction for the computation of absolute difference of two vectors of numbers 
according to one embodiment of the present invention. 

[0089] Figure 35 shows a flow diagram for a method of computing the absolute 
difference of two vectors of numbers according to one embodiment of the present 
invention. 

[0090] Figure 36 shows a flow diagram for a method of computing the absolute 
difference of two numbers according to one embodiment of the present invention. 
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[0091] Figure 37 illustrates a block diagram representation of a circuit for the 
execution of a method to perform table look-up of a vector of data elements 
according to one embodiment of the present invention. 
[0092] Figure 38 illustrates a block diagram representation of a circuit for 
configuring look-up units into different look-up tables according to one embodiment 
of the present invention. 

[0093] Figure 39 illustrates another block diagram representation of a circuit for 
configuring look-up units into different look-up tables according to one embodiment 
of the present invention. 

[0094] Figure 40 illustrates data representations for the execution of an 
instruction for performing table look-up of a vector of data elements according to 
one embodiment of the present invention. 

[0095] Figures 41 - 43 illustrate block diagram representations of circuits for 
performing table look-up of vectors of different sizes using a set of look up units 
according to one embodiment of the present invention. 

[0096] Figure 44 shows a flow diagram for a method to perform table look-up 
of a vector of data elements according to one embodiment of the present invention. 
[0097] Figure 45 illustrates a block diagram representation of a circuit for the 
execution of a method to load entries in look-up units using DMA controllers 
according to one embodiment of the present invention. 

[0098] Figure 46 illustrates data representations for the execution of a method to 
load entries in look-up units using DMA controllers according to one embodiment of 
the present invention. 
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[0099] Figure 47 shows a flow diagram for a method to load entries in look-up 
units using DMA controllers according to one embodiment of the present invention. 
[00100] Figure 48 illustrates a block diagram representation of a circuit for the 
execution of a method to set entries in look-up tables according to one embodiment 
of the present invention. 

[00101] Figure 49 illustrates data representations for the execution of a method to 
set entries in look-up tables according to one embodiment of the present invention. 
[00102] Figure 50 shows a flow diagram for a method to set entries in look-up 
tables according to one embodiment of the present invention. 
[00103] Figure 51 illustrates a block diagram representation of a circuit for the 
execution of a method to perform variable length decoding according to one 
embodiment of the present invention. 

[00104] Figures 52 - 53 illustrate block diagram representations of circuits for 
performing variable length decoding using a set of look up units according to one 
embodiment of the present invention. 

[00105] Figure 54 illustrates a detailed block diagram representation of a circuit 
to select a segment of bits from a bit stream according to one embodiment of the 
present invention. 

[00106] Figure 55 illustrates a detailed block diagram representation of a circuit 
to select a valid data from the look-up results of a number of look-up tables 
according to one embodiment of the present invention. 
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[00107] Figure 56 illustrates a detailed block diagram representation of a circuit 
to format a valid data from a look-up table according to one embodiment of the 
present invention. 

[00108] Figure 57 illustrates a detailed block diagram representation of a circuit 
to format an escaped data from a bit stream according to one embodiment of the 
present invention. 

[00109] Figure 58 illustrates a detailed block diagram representation of a circuit 
to format an escaped data obtained from a bit stream according to one embodiment 
of the present invention. 

[00110] Figure 59 illustrates a detailed block diagram representation of a circuit 
to generate the result of variable length decoding using the escaped data and the data 
from look-up tables according to one embodiment of the present invention. 
[00111] Figure 60 illustrates data representations for the execution of a method to 
perform variable length decoding according to one embodiment of the present 
invention. 

[00112] Figure 61 shows a flow diagram for a method to perform variable length 
decoding according to one embodiment of the present invention. 
[00113] Figure 62 shows look-up tables for variable length decoding code words 
encoded using DV standard according to one embodiment of the present invention. 
[00114] Figure 63 shows a flow diagram for a method to decode a DV video 
stream in one stage. 

[00115] Figure 64 shows a flow diagram for a method to decode a DV video 
stream in two stages. 
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[00116] Figure 65 shows a flow diagram for another method to decode a DV 
video stream in two stages. 

[00117] Figure 66 shows a flow diagram for a method to decode a DV video 
stream in three stages. 

[00118] Figure 67 shows a detailed flow diagram for a method to transfer 
data while decoding a video stream. 

[00119] Figure 68 shows a detailed flow diagram for a method to transfer 
data while variable length decoding a segment of a video stream. 
[00120] Figure 69 shows a detailed flow diagram for a method to transfer 
data while inverse discrete cosine transforming macro blocks of a video stream. 
[00121] Figure 70 shows a memory management scheme for a method to 
transfer data while decoding a video stream. 

[00122] Figure 71 shows a memory management scheme for a method to 
transfer data while variable length decoding a segment of a video stream. 
[00123] Figure 72 shows a memory management scheme for a method to 
transfer data while inverse discrete cosine transforming macro blocks of a video 
stream. 

[00124] Figure 73 shows a flow diagram for a method to decode a bit stream 
by using a plurality of execution units concurrently. 

[00125] Figure 74 shows a data structure for storing either remaining bits or 
incomplete code bits. 

[00126] Figure 75 shows methods to transpose a matrix using operations that 
change the positions of the elements within rows or within columns. 
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[00127] Figure 76 shows examples of indices that may be used in a plurality 
of look up tables to change the positions of the elements within columns. 
[00128] Figure 77 shows a method to transpose a matrix using a vector 
processor according to one embodiment of the present invention. 
[00129] Figure 78 shows a flow chart for a method to transpose a matrix 
using a VLIW processor according to one embodiment of the present invention. 
[00130] Figure 79 shows an example of a method to look up a vector of data 
items of extended precision according to one embodiment of the present invention. 
[00131] Figure 80 shows an example of a method to look up two vectors of 
data items in parallel for one vector of indices according to one embodiment of the 
present invention. 

[00132] Figure 81 shows an example of a method to look up two vectors of 
data items in parallel for two vectors of indices according to one embodiment of the 
present invention. 

[00133] Figure 82 shows an example of a method to look up two vectors of 
data items of extended precision in parallel for one vector of indices according to 
one embodiment of the present invention. 

[00134] Figure 83 shows another example of a method to look up two vectors 
of data items of extended precision in parallel for one vector of indices according to 
one embodiment of the present invention. 

[00135] Figure 84 shows a method to blend two images using a vector look 
up unit according to one embodiment of the present invention. 
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[00136] Figure 85 shows a method to look up vectors of blending factors 
using a vector look up unit according to one embodiment of the present invention. 
[00137] Figure 86 shows a method to look up two vectors of data items in 
parallel for two vectors of indices using a vector look up unit according to one 
embodiment of the present invention. 

[00138] Figures 87 - 89 show flow charts for methods to look up two vectors 
of data items in parallel for one or two vectors of indices. 
[00139] Figure 90 shows an example of a method to convert a vector of 
elements into another vector of elements using a vector look up unit according to 
one embodiment of the present invention. 

[00140] Figure 91 shows an example of a method to convert a vector of 
elements into another an element of another vector using extended precision in a 
vector look up unit according to one embodiment of the present invention. 
[00141] Figure 92 shows a flow chart for a method to convert a vector of 
elements into another vector of elements using a vector processor according to one 
embodiment of the present invention. 

[00142] Figure 93 shows a flow chart for a method to convert a vector of 
elements into another vector of elements using a VLIW processor according to one 
embodiment of the present invention. 

[00143] Figure 94 shows a method to encode a DV video stream in three 
stages. 

[00144] Figure 95 shows a memory management scheme for a method to 
transfer data in a Forward Discrete Cosine Transformation stage. 
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[00145] Figure 96 shows a memory management scheme for a method to 
transfer data in a Quantization stage. 

[00146] Figure 97 shows a memory management scheme for a method to transfer 
data in an Entropy Coding stage. 
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DETAILED DESCRIPTION 



[00147] The following description and drawings are illustrative of the 
invention and are not to be construed as limiting the invention. Numerous specific 
details are described to provide a thorough understanding of the present invention. 
However, in certain instances, well known or conventional details are not described 
in order to not unnecessarily obscure the present invention in detail. 
[00148] Figure 1 shows an example of a typical computer system, which may 
be used with the present invention. Note that while Figure 1 illustrates various 
components of a computer system, it is not intended to represent any particular 
architecture or manner of interconnecting the components as such details are not 
germane to the present invention. It will also be appreciated that network computers 
and other data processing systems which have fewer components or perhaps more 
components may also be used with the present invention. The computer system of 
Figure 1 may, for example, be an Apple Macintosh computer. 
[00149] As shown in Figure 1, the computer system 1 100, which is a form of 
a data processing system, includes a memory controller 1102 which is coupled to a 
host processor or processors 1 101 and a host memory 1 103 which may include a 
read only memory (ROM), volatile random access memory (RAM), and a non- 
volatile memory. The host processor 1 101, is coupled to cache memory 1 108 as 
shown in the example of Figure 1. The core logic 1 102 may also be coupled to the 
bus 1 104. The bus 1 104 interconnects the system to PCI peripheral components, 
such as a display controller and display device 1106 and to peripheral devices such 
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as input/output (I/O) devices which may be mice, keyboards, modems, network 
interfaces, printers and other devices which are well known in the art. Typically, the 
input/output devices 1107 are coupled to the system through input/output controllers 
1 105. The bus 1 104 may include one or more buses connected to each other through 
various bridges, controllers and/or adapters as is well known in the art. In one 
embodiment the I/O controller 1105 includes a USB (Universal Serial Bus) adapter 
for controlling USB peripherals. 

[00150] Figure 1 also shows a system core logic chip 1 102 providing 
interfaces to the host processor 1 101 and host memory 1 103. The system core logic 
chip 1 102 also acts as a bridge between the bus 1 104 and the host processor 1 101 
and the host memory 1 103. The system core logic 1 102 is also known as a memory 
controller or a north bridge. A typical graphics controller 1 106 receives graphics 
data from the host processor 1 101 and the host memory 1 103 through the system 
core logic 1 102 and the bus 1 104. 

[00151] Figure 2 shows another example of a typical computer system, which 
may be used with the present invention. The system 1200 of Figure 2 includes a 
host processor or processors 1201 coupled to a system core logic 1202, a host 
memory 1203 coupled to the system core logic 1202. The bus 1204 interconnects 
these various components together and also interconnects these components 1201 
and 1203 to a display controller and to peripheral devices such as input/output (I/O) 
devices 1207 through an I/O controller 1205. The bus 1204 may be a peripheral 
component interconnect (PCI) bus. A graphics controller 1206 is coupled to the 
system core logic 1202 through an interface such as accelerated graphics port (AGP) 
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interface integrated with the system core logic 1202. The graphics controller 1206 is 
typically coupled to a display device 1211, such as a monitor or TV station. The 
graphics controller 1206 may be connected to an input of a video editing system. 
[00152] The present invention in one embodiment integrates a media 
processor in a system core logic chip such as system core logic 1 102 of Figure 1 or 
1202 of Figure 2. The system core logic chip typically is memory controller and is 
referred to as a north bridge. Figure 4B shows an example of one embodiment of 
the present invention. The system core logic 1410, which may be implemented as a 
single chip (integrated circuit) or multiple chips, includes a host interface 1414 
coupled to the host processor 1411. The host interface 1414 provides accesses 
between the host processor 1411 and the logic 1410. The logic 1410 also includes a 
memory interface 1415 for controlling and accessing the host memory 1412 from the 
logic 1410. A media processor 1413 is integrated in the logic 1410. In one 
embodiment, this integration means that if logic 1410 is contained all on one chip 
(IC) then the media processor 1413 is on the same IC (e.g., same monolithic 
integrated circuit substrate). The logic 1410 also may include a PCI-0/AGP interface 
1417. In one embodiment, the PCI-0/AGP interface may provide an interface to 
other external PCI devices. In another embodiment, the PCI-0/AGP interface 1417 
may serve as an accelerated graphics port (AGP) coupled to an external graphics 
controller 1419. The graphics controller 1419 may be coupled to a display device 
1425, such as a monitor or a TV station. The graphics controller 1419 may be 
coupled to an input of a video editing system. The logic 1410 may include a PCI-1 
interface 1418. The PCI-1 interface may be coupled to another PCI device or it can 
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be coupled to an input/output (I/O) controllerl420, also known as south bridge. 
Together, the north bridge and the south bridge may be referred to as a chipset. The 
I/O controller 1420 may provide as a bridge to other PCI buses which may connect 
more PCI devices, such as an Ethernet device, a modem, etc. In one embodiment, an 
IEEE- 1394 bus 1421, also known as FireWire bus, may be coupled to the I/O 
controller 1420. In another embodiment, the FireWire bus 1421 may be directly 
coupled to the system core logic chip 1410 through PCI like interface. A bus 1416 
interconnects all components together. In an alternative embodiment, the logic 1410 
may include interfaces to many other components of the system, such as universal 
serial bus (USB), Ethernet device, etc. Other configurations may exist. One of the 
advantages of the present invention is that a media processor is built on a 
conventional system core logic chip which has more unused space. As a result, the 
cost of the system has been reduced, by combining a conventional system core logic 
with a media processor into a single-chip of a chipset. 

[00153] As shown in Figure 4B, in one embodiment, the media processor 
1413 communicates with the host processor 1411 through the host interface 1414 
and accesses the host memory 1412 through the memory interface 1415. The media 
processor 1413, in one embodiment, processes data autonomously and 
asynchronously to the host processor 141 1. In another embodiment, the media 
processor 1413 communicates with the host processor 1411 through an interrupt 
mechanism. A software program executed by the host processor 1411 may control 
the interrupt mechanism. The media processor, in one embodiment, is capable of 
processing multiple media data streams simultaneously. Each media data stream 
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may be a time related sequence of data representing related images (or audio data or 
both related image and audio data such as a motion picture). Thus, for example, a 
first image and a second image are related by a first time (e.g., the first image is 
shown 1 second, at normal playback speed, before the second image) and a third 
image and a fourth image are related by a second time (e.g., the third image is show, 
at normal play back speed, 2 seconds before the fourth image), and the third image is 
shown 1 second before the second image. It will be appreciated that these time 
durations (e.g., 1 second) are used for discussion purpose only that other times may 
be used. Often, information specifying such times is included in the media data 
stream which are processed by the media processor. Such media data streams may 
be referred to as time based media. Time based media include Quicktime movies 
and Quicktime streaming movies, and examples of time based media are provided in 
U.S. Patent No. 6,134,243, which is hereby incorporated herein by reference. 
[00154] Figure 5B shows an example of one embodiment of a media 
processor of the present invention. The media processor 1510 can be used as the 
media processor 1413 of Figure 4B. Referring to Figure 5B, the media processor 
1510 may contain multiple compute engines such as compute engine 1520. Multiple 
compute engines including compute engine 1520 are coupled to a chip interconnect 
1519. The number of the compute engines is scalable and may be determined by the 
particular requirements for system performance versus chip size and cost. The 
media processor 1510 also includes a stream interface 1521 for gathering and 
distributing requests to and from the compute engine 1520 and the rest of the system. 
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[00155] The stream interface 1521 contains a memory mapping mechanism to 
convert linear logical addresses used by the compute engine 1520 to physical address 
for snooping and accessing memory. In one embodiment, the memory mapping 
mechanism contains a video address re-mapping table (VART) 1515, which is 
further described below, coupled to a memory management controller (MMC) 1516. 
The MMC 1516 receives a memory access request and determines whether such 
request needs to be mapped from a logical address to a physical address. If the 
memory request does not need to be mapped, the MMC 1516 will send the request to 
the coherent stream interface 1513 or the non-coherent stream interface 1514 
directly. If the memory request needs to be mapped, the MMC 1516 will send the 
request to the VART 1515 for translation from logical addresses to physical 
addresses. The stream interface 1521 may also contain a compute engine to compute 
engine interface (not shown) providing accesses among the multiple compute 
engines. 

[00156] One of the advantages of the media processor of one embodiment of 
the present invention is that both cache coherent and cache non-coherent interfaces 
are integrated in the single-chip north bridge which includes the media processor and 
the memory controller. This feature provides more flexibility over a conventional 
media processor. A conventional media processor normally uses mapped non- 
coherent memory access only. Cache non-coherent memory operations are those 
operations where data goes directly to and from memory and is returned directly 
back to the media processor and never goes through a processor cache. With cache 
non-coherent memory access, the data in the main memory may not be synchronized 
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with those in the host processor's cache memory. A coherency between the host 
processor's cache memory and the main memory must be maintained (e.g., by 
software program), such that the data in the host processor's cache memory are 
synchronized with those in the main memory. On the other hand, a cache coherent 
memory system always goes through the host processor. The data of a cache 
coherent memory system may exist in the host processor's cache memory or in the 
host memory. Referring to Figure 5B, when a coherent memory access request is 
issued, the host processor 1511 checks whether the host processor cache memory 
1524 contains newer data than the host memory 1512. If the host processor cache 
1524 has newer data, the host processor 1511 flushes its caches into the host 
memory 1512 before the data being read from the host memory 1512. With cache 
coherent memory system, the coherency between the host processor's cache memory 
1524 and the host main memory 1512 is maintained by the host processor. 
However, cache coherent memory access is normally slower than cache non- 
coherent memory access. The present invention, in one embodiment, integrates both 
cache coherent and cache non-coherent interface for both memory accesses into the 
north bridge chip of the north/south bridge chipset, which provides great flexibility 
over a conventional design. 

[00157] Figure 6 shows a method used in an alternative embodiment of the 
present invention, such as the one shown in Figure 4B. Referring to Figure 6, the 
cache coherent interface receives a cache coherent access request in operation 1615, 
the cache coherent interface transmits the request to the host interface 1619. The 
host interface 1619 sends a cache coherency message to the host processor 1616. 
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During the memory read access, the host processor 1616 checks whether its cache 
contains newer data than the host memory 1618. If the host processor's cache 
contains newer data than the host memory, the host processor flushes its cache to the 
host memory 1618. Then the cache coherent interface 1615 reads the data from the 
host processor's cache. During the memory write access, the cache coherent 
interface 1615 writes the data to the host memory 1618, thereafter, upon receiving 
the cache coherency message, the host processor 1616 refreshes its cache from the 
host memory 1618 to synchronize the data between its cache and the host memory. 
Upon receiving the cache coherency message, the host interface 1619 also snoops 
the request for cache coherency violations. If the violations occur, an error message 
will be generated through an interrupt mechanism. 
[00158] The memory requests of Figure 6 come from three sources: 
command queue fetch mode (CQM), instruction cache fill mode (ICM), and direct 
memory access (DMA) mode (DCM). The MMC 1516 of Figure 5B may comprise 
a memory management control register (MMCR). In another embodiment, each 
compute engine such as compute engine 1520 of Figure 5B comprises its own 
MMCR. The MMCR determines the type of the request sent to memory. Figure 7 
shows the layout of one embodiment of a MMCR. The MMCR 1700 contains 32 
bits. The MMCR 1700 comprises three separate codes for each of the three sources 
of the memory requests. The CQM code 1701 occupies bit 23 to bit 25, the ICM 
code 1702 occupies bit 26 to bit 28, and DCM code 1703 occupies bit 29 to bit 31. 
These codes specify whether the request is mapped/unmapped and coherent/non- 
coherent, as described in table 1704. In an alternative embodiment, bit 0 of the 
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logical address may specify whether the request is mapped/unmapped and 
coherent/non-coherent. For mapped addresses the fields in the VART table entry 
may determine if the access is coherent or non-coherent. The host processor such as 
host processor 151 1 of Figure 5B updates the MMCR through a memory mapped 
address such as memory mapped registers 1523, through the master interface 1522 of 
Figure 5B. The fields of the MMCR are initially undefined; they must be loaded 
before a memory access can occur. 

[00159] The memory mapping mechanism of Figure 5B also determines 
attributes to control cache coherency. As shown in Figure 5B, the stream interface 
1521 also contains a coherent stream (CS) interface 1513 and a non-coherent stream 
(NCS) interface 1514. For the CS interface, requests are sent to the host processor 
151 1 to be snooped by the host processor's caches. CS requests are used for 
memory data that may reside in the host processor's caches or the data that may 
reside in the targeted memory mapped addresses. NCS requests are sent directly to 
the host memory 1512 and are used for data requests that require high bandwidth. 
Such coherency is maintained through software. Thus, the software is responsible 
for synchronizing the host caches and the host memory. The stream interface 1521 
may also include a master interface 1522. The master interface 1522 provides the 
host processor 1511 with the ability to control the operation of the compute engine 
1520. In one embodiment, the host processor 1511 controls the operation of the 
compute engine 1520 through a set of memory mapped registers 1523. Among other 
things, these memory mapped registers 1523 define a command queue, which is 



04860.P2687 



39 



described further below, from which commands or routines are sent to the compute 
engine 1520, MMCR as described above and various interrupt control mechanisms. 
[00160] Memory access requests from compute engines are labeled as being 
mapped or unmapped. Unmapped requests are also labeled as being coherent or 
non-coherent. Mapped requests undergo a mapping from their linear logical address 
provided by the compute engine, such as compute engine 1806 of Figure 8. The 
mapping also determines if the request is coherent or non-coherent, which is 
described further below. Referring to Figure 8, a mapped request from the compute 
engine 1806 is sent to a video address re-mapping table (VART) 1805 for translation 
from a linear logical address to a physical address. The VART 1805 then determines 
whether the request is coherent, if so, the VART 1805 sends the request to the 
coherent interface 1803 and then out to the host processor 1801. If the request is 
non-coherent, the VART 1805 sends the request to non-coherent interface 1804 and 
then out to the host memory 1802. Coherent and non-coherent interfaces and the 
VART are part of the stream interface 1807. 

[00161] In a modern computer system, two address spaces are present. The 
logical address space and the physical address space. The logical address space is 
the address space accessed by the software running on the host and there is a logical 
address space accessed by the software running at the video stream processor (VSP) 
such as the media processor 1510. The physical address space is a set of address 
ranges occupied by the system hardware devices and system memory. The address 
re-mapping tables provide the mapping between the logical addresses used by the 
software in order to access physical devices at their physical addresses. VART is the 
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table that maps logical addresses used by the VSP engine to the physical addresses 
of the main memory and other system devices. 

[00162] In one embodiment of the invention, the tables are located in the main 
memory and addressed by their physical address without any address translation. 
Different devices may access the same physical location using different logical 
address, provided that these logical addresses are mapped to the same physical space 
by a re-mapping table. It may be possible for VSP engine to directly access other 
physical devices, such as AGP or PCI devices, when the proper mapping is provided 
by the VART. The memory management software which is part of the operating 
system (OS) kernel software is responsible for allocating physical memory, 
assigning to some logical addresses and storing the mapping information in the 
address re-mapping tables. For the VSP devices, the physical memory regions must 
be allocated and mapped to logical addresses prior to any VSP command execution 
that will access that memory regions. The system software sets up the VART entries 
accordingly. The memory mapping should stay valid until the command execution 
is completed. When the shared memory ranges are no longer needed by the VSP, the 
host or other devices, the physical memory may be freed and the corresponding 
VART entries are invalidated. Pages are the usual mechanism used for addressing 
information in a memory system. An example of logical to physical address 
mapping from a VSP is described further below. 

[00163] The video address mapping table (VART) is made up of table entries. 
Each table entry corresponds to a logical page in the address space assigned to the 
media processor. The table entry contains information about the corresponding 
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physical memory page number as well as if the memory access is cache coherent. 
The system software is responsible for maintaining VART, whether a page is 
allocated for use by the media processor, the system software creates a 
corresponding entry in the VART, and marks it as valid. When the page is freed, the 
VART entry is marked invalid. 

[00164] Physical addresses are allocated in pages (e.g., each page has 4096 
bytes). Pages are the usual mechanism used for addressing information in a logical 
memory system. Pages are numbered and both physical and logical addresses often 
include a page number and an offset into the page. As an example, referring to 
Figure 11, the VART 2107 contains entries that include the addresses of pages i, j, 
and k. Each VART page in the logical address space has a corresponding page in 
physical memory space. For example, VART page 2104 has a corresponding 
physical page 2110. In this example, the VART 2107 contains valid entries for 
mapping pages i 2104, page j 2105, and page k 2106 in the logical address space into 
corresponding physical page i 2110, page j 2109, and page k 2111 respectively. 
When a request for mapping is received, the logical page frame number (LPN) will 
be extracted from a logical address of address space 2101. The VART entry 
corresponding to the LPN will be extracted. If a valid entry is found, the PPN will be 
extracted and the physical address will be determined and the logical address is 
mapped to a physical address. 

[00165] One of the advantages of the VART 2107 in the present invention is 
that the video device address space can be overlapped the logical address space 
2101. Such video device address space can be shared by other devices, or the host 
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processor such as host processor 151 1 of Figure 5B. On the other hand, a 
conventional graphics controller coupled to an accelerated graphics port (AGP) has 
its own dedicated address space. In general, such address space is allocated by the 
software during the boot time of the system. Such address space cannot be used by 
any other components of the system. System software indicates the access to the 
corresponding physical memory by different devices. If the video stream processor 
(VSP) address space overlaps the system address space, only one address may need 
to be allocated. On the other hand, if the address spaces are disjoint, the system 
software may use two logical addresses to access some logical page of physical 
memory. As a result, such address space cannot be used by others, even though the 
AGP graphics device is not using them. This limitation posts an inconvenience to 
the memory management, as well as the cost of the memory bandwidth of the host 
system. 

[00166] A conventional graphics address re-mapping table (GART), such as 
GART 2108 can only map a dedicated graphics accelerator address space such as 
AGP device address space 21 14. Unlike GART, the VART of the present invention 
can map a logical address space located almost anywhere in the logical address space 
2101. In an alternative embodiment of a system of the invention, the system 
includes a VART in addition to a GART and host maintained tables. In fact, in one 
embodiment, the video device address space 2103 can be the same range as the AGP 
device address space 2114. This advantage provides more flexibilities and 
bandwidth to the system. 
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[00167] When a media processor of the present invention processes multiple 
media data, the application software or the system software is responsible to allocate 
enough memory resources for the processing. In one embodiment, a large block of 
memory may be pre-allocated before any data processing occurs. In another 
embodiment, the memory allocation may be performed dynamically as needed. 
When a page is allocated for use by VSP, the system software updates the VART 
entry corresponding to the LPN of its logical address with the PPN of the newly 
allocated physical memory page. After processing the media data, if the physical 
memory page is no longer needed, the physical memory page is released back to the 
main memory and the corresponding entry of the VART is marked invalid. 
[00168] The VART normally comprises a VART base register (VARTBASE) 
and a VART size register (VARTSIZE). Figure 9 shows an embodiment of a 
VART entry, as well as VARTBASE and VARTSIZE. Referring to Figure 9, 
VARTBASE 1906 defines the location of the VART and the VARTSIZE 1907 
defines how big the VART is in 64-bit words. Both VARTBASE and VARTSIZE 
comprise 19-bit data. In one embodiment, VARTBASE occupies from bitO to bit 19 
and VARTSIZE occupies from hit 13 to bit 31. Each VART entry maps two 4K- 
Byte pages, including an even page 1901 and an odd page 1902. Each entry of even 
or odd page contains a physical page frame number (PPN), which occupies from bitO 
to bitl9. The entry also contains a coherent bit (C-bit), which indicates whether the 
mapping is coherent access. A logical value of one indicates the mapping is 
coherent. The entry further contains a valid bit (V-bit) indicating whether the entry 
is valid. A logical value of one indicates the entry is valid. The V-bit is initially set 
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to invalid (e.g., logical value of zero), until a physical memory page is allocated and 
the VART is updated. These bits may be set by a software program that allocates the 
pages. 

[00169] A logical address (LA) that needs to be mapped contains a logical 
page frame number (LPN) and an offset. A typical LPN has 19 bits, from bitO to 
bitl8. Bit 20 to bit 31 are the offset of the logical address. Before a mapping takes 
place, the LPN will be compared with the VARTSIZE register to determine if the 
request is out of boundary of the VART. If the request does not fit in the VART, a 
VART out-of-bound exception is set and an interrupt is issued. The out-of-bound 
exception is described as follow: 

OutOfBoundException = (Size <= LA [0:18]) 
where the Size value is extracted from the VARTSIZE register, VARTSIZE[13:31]. 
The LPN is extracted from the logical address. If the request bits in the VART, 
LA[0:9] are added to the VARTBASE and the value at these locations concatenated 
to LA[10:18] to form the physical address location of the logical address. The 
VART PTE address is described as follow: 

VART PTE Address = ((LPN[0:9] + VARTBASE) || LPN[10:18]) « 3 
The VART PTE is fetched and the even or odd page entry is selected based on 
LPN[19]. The valid bit is checked and if it is found to be not valid, a VART entry 
exception is set. The exception is issued through an interrupt mechanism. If the 
entry is found to be valid, the physical page frame number (PPN) is concatenated to 
the offset of the logical address [20:31] bits to form the physical address. A request 



04860.P2687 



45 



is sent to the coherent interface if the C-Bit of the entry is set to logical value of one, 
otherwise the request is sent to the non-coherent interface. 
[00170] Figure 12 shows a method used in one embodiment of the present 
invention to map a logical address to a physical address. Referring to Figure 12, a 
logical address 2200 contains a logical page frame number (LPN) 2201 and an offset 
2202. The LPN 2201 is retrieved from the logical address 2200 and is combined 
2204 with the VARTBASE 2203 to form a VART PTE address 2205. Based on the 
PTE address 2205, an entry is fetched from the corresponding entry address 2205 of 
the VART. A physical page frame number (PPN) 2208 is retrieved from the entry. 
Then the PPN 2208 will be combined 2207 with the original offset 2202 of the 
logical address 2200 to form a physical address 2209. The request will be checked 
whether the request is intended for coherent access or for non-coherent access, based 
on the C-Bit 221 1 of the PTE entry of the VART 2206. The request will be sent to a 
proper memory interface 2210, coherent or non-coherent interface. Finally, the 
request will be sent through either coherent or non-coherent interface to the main 
memory 2212. 

[00171] Figure 15 shows a method of mapping a logical address to a physical 
address through the VART. Referring to Figure 15, the method starts with 
retrieving 2501 the LPN from the logical address and retrieving 2502 the size of the 
VART from VARTSLZE register. The LPN is compared with the size of the VART 
in operation 2503. If the LPN value is greater than the size of the VART, an 
exception will be thrown 2504 through an interrupt mechanism. If the LPN can fit 
in the VART, the base address of the VART will extracted 2505 from the 
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VARTBASE register. The base address of the VART and the LPN will be 
combined to generate 2506 a VART PTE address. The entry of the VART 
corresponding to the PTE address is fetched. The entry of VART contains an even 
page and an odd page. The even or odd page is selected 2507 based on the page 
selection bit (e.g., bit 19 of the logical address) of the logical address. The page 
entry is checked 2508 whether such entry is valid by checking the valid bit V-Bit of 
the page entry of the VART. If the page entry is not valid, an exception will be 
issued 2504. If the page entry is valid, the physical page frame number (PPN) will 
be retrieved 2509 from the PTE. A physical address is then generated 1520 by 
combining the PPN of the PTE of VART with the offset of the logical address. 
[00172] Any memory access from a compute engine (e.g., compute engine 
1520 of the media processor 1510 in Figure 5B) that results in an exception is 
aborted and a memory access exception is sent to the requesting compute engine. 
Recently used accesses to the VART are cached in the VART table look-aside buffer 
(TLB). The VART TLB is a cache memory of recently used VART table entries. It 
comprises a 128-entry TLBTag ram in a 4-way set-associative arrangement (32 sets 
of 4 ways per set), and a corresponding 256-entry TLBData ram. Each TLB entry is 
capable of mapping 2 logical addresses using 2 entries of the TLBData ram. This 
gives the TLB the capability of mapping a total of 256 pages, while saving some 
memory bandwidth for the TLB. 

[00173] Figure 10A shows an example of a layout of the VART TLB 
including TLBTag and TLBData entries, used in one embodiment of the present 
invention. Each entry of the TLBTag ram, such as TLB Tag entry 2000, comprises a 
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logical page frame number (LPN) tag bits [0:13] 2001 and two valid bits: even page 
valid bit VE bit 2002 and odd page valid bit VO bit 2003, corresponding to the even 
and odd page frames of the VART entry. Each entry of the TLBData ram, such as 
TLB Data entry 2004, comprises a physical page frame number (PPN) [0:19] 2005 
and a C-Bit 2006 for coherency. The VART TLB is accessible through memory- 
mapped addresses. 

[00174] The translation process using the TLB consists of splitting the logical 
address into three fields: bits [0:13] are the logical address tag (LogAdrsTag), bits 
[14:18] are the TLB index bits (TLBIndex [0:4]), and bit [19] is the even/odd page 
selection bit. The TLBIndex accesses the four sets of TLBTag entries. The 
TLBTags from the 4 ways are compared to the LogAdrsTag fields. On entries that 
match, the even or odd valid bit is selected based upon the even/odd page selection 
bit (e.g., bit 19) of the logical address. If the entry is valid, then the way number is 
encoded and used along with the TLBIndex and the even/odd selection bit to access 
the 256-entry TLBData ram. The odd or even PPN and C-Bit is selected from the 
TLBData ram and used to complete the mapping. The page frame number is 
concatenated to the offset of the logical address (bits [20:31]) to complete the 
physical address. A request is sent to the coherent interface if the C-Bit of the entry 
has a logical value of one, otherwise the request is sent to the non-coherent interface. 
If there is no matched entry found in the VART TLB, the VART table entry will be 
used to complete the mapping and the TLB entry will be updated. 
[00175] The VART TLB also includes a least recently used (LRU) 
replacement mechanism to determine which entry is updated. An entry is considered 
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"used" when a valid mapped request hits in the entry. The initial state (after the TLB 
is invalidated) of a set of four entries is the order (0,1,2,3) where way-0 is the LRU 
and the way-3 is the most recently used (MRU). The entry of TLB with lower order 
is replaced with the one with higher order. 

[00176] Figure 14 shows a method for mapping a logical address to a 
physical address with a VART TLB, used in one embodiment of the present 
invention. Upon receiving an address-mapping request in 2401, the VART TLB will 
be searched 2402 to find an entry matching the logical page frame number (LPN) of 
the logical address. If the VART TLB is missed (e.g., a matched entry is not found), 
a VART PTE address is generated 2403 from the LPN and a PPN is fetched 2404 
from the corresponding PTE entry of the VART. After the corresponding PTE is 
found, the VART TLB will be updated to cache the PTE used. If the VART TLB is 
hit (e.g., a matched entry is found), the PPN will be fetched directly from the TLB. 
Then the LRU is updated 2406 and a physical address is generated 2407 from the 
PPN and the offset of the logical address. After the physical address is generated, a 
C-Bit either from the VART PTE or the VART TLB entry is checked 2408 to 
determine whether the request is for coherent access. If the request is for coherent 
access, the request is sent 2409 to a coherent interface; otherwise the request is sent 
2410 to a non-coherent interface. 

[00177] It is important to note that the VART of the present invention can 
map the logical address anywhere in the system address space, which space can be 
shared with other components in the system. The VART can also map a dedicated 
address space such as AGP device address range, in which case, the AGP address 
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space cannot be shared with other components in the system. It is also important to 
note that the configuration of the VART in the present invention can be used in a co- 
processor to the host processor, a stand-alone processor, or a processor integrated in 
a system core logic chip such as the system core logic chip 1410 of Figure 4B. 
[00178] After mapping an address through the VART, an address decoding is 
performed to determine if the address is valid and whether the request should be sent 
to memory, PCI-0, or another compute engine. If an address is determined to be 
invalid, a memory address exception is generated through an interrupt mechanism. 
If the access is to memory (e.g., high order bit is zero), any address is valid. If the 
access is to another compute engine (e.g., high order byte matches the compute 
engine's ID in a control register), the address is checked to make sure it is a valid 
compute engine. If the access is to PCI-0 (e.g., high order bit is non-zero and high 
order byte does not match the compute engine's ID), the address is checked for the 
validity against the PCI-0 address mask register. This register is located in PCI-0 
and is accessible through system address mapping. This register defines the valid 
address space for PCI-0. The format of the PCI-0 mask register is shown as 2010 of 
Figure 10B. 

[00179] The media processor of the present invention such as media processor 
1510 of Figure 5B has multiple compute engines such as compute engine 1520. 
Each engine can process multiple media data simultaneously. Figure 17 shows an 
example of an embodiment of a compute engine of the present invention. The 
compute engine 2700 comprises an input and output (I/O) interface 2707 receiving 
and transmitting media data from and to the rest of the system. The I/O interface 
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2707 receives the data from the system (e.g., host memory) and transmits the data to 
the branch and instruction unit 2706. The branch and instruction unit 2706 decodes 
the instruction and load the data into a local memory location 2704. The branch and 
instruction unit 2706 then dispatches the instructions to the scalar processing units 
2703 and vector processing units 2705. Scalar processing unit 2703 processes the 
scalar data operation (e.g., integer arithmetic operation) and vector processing unit 
2705 processes vector data operation (e.g., vector adds or subtract). The source and 
destination operand may be stored in register files. Scalar processing units use 
general-purpose register (GPR) files 2701 and vector-processing units use a vector 
register (VR) files 2702. 

[00180] One of the advantages of one embodiment of the present invention is 
that both scalar unit and vector unit are integrated in the media processor. 
[00181] Figure 18 shows a detailed depiction of an embodiment of a compute 
engine of the present invention. Referring to Figure 18, the compute engine 2800, 
also known as video geometry engine (VEO), can be considered as a VLIW 
processor executing a set of instructions. Such instructions can be a subset of the G4 
instruction set used by a Macintosh computer with extensions. The compute engine 
2800 does not perform any hardware instruction scheduling. All codes run on the 
compute engine are assumed to have correct resource and dependency scheduling. 
[00182] Each compute engine consists of a set of functional units. In one 
embodiment, there may be eight functional units integrated in the compute engine 
2800: integer arithmetic/logical unit (IALU) 2805, integer shift unit (ISHU) 2806, 
load/store unit (LSU) 2816, vector permute unit (VPU) 2808, vector simple integer 
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unit (VSIU) 2809, vector complex integer unit (VCIU) 2810, vector look-up table 
unit (VLUT) 281 1, and branch/instruction unit (BRU) 2821. There are six storage 
elements in the compute engine 2800: general purpose register file (GPR) 2801, 
vector register file (VR) 2802, look-up table (LUT) (not shown, located in the VLUT 
2811), local memory 2817, instruction cache 2820, and special purpose registers 
(SPR). In another embodiment, the compute engine 2800 also includes a floating- 
point unit (FPU) 2807 and vector floating-point unit (VFPU) 2812. In a further 
embodiment, the compute engine 2800 may also include a floating-point register file 
(not shown), for floating-point data processing. It is useful to note that a compute 
engine may contain all or a subset of the above-functional units. Furthermore, more 
than one functional unit of a kind may be included. For example, in one 
embodiment, a compute engine may comprise one IALU, two ISHU, one LSU, and 
one BRU units. 

[00183] The integer arithmetic/logic unit (IALU) 2805 executes simple scalar 
integer arithmetic (e.g., addition and subtraction, etc.), and logical operations. These 
are pipelined to dispatch in a single clock cycle. The IALU 2805 also executes 
complex scalar arithmetic instructions such as multiplication and division in 
multiple clock cycles. Source and destination data is accessed from the GPR 2801. 
The integer shift unit (ISHU) 2806 executes scalar bit shift and rotate operations. 
These are pipelined for single clock cycle dispatch. Source and destination data is 
accessed from the GPR 280 L 

[00184] The load/store unit (LSU) 2816 executes the instructions for loading 
and storing scalar data for the GPR file 2801, and loading and storing vector data for 
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the VR file 2802. The load and store data comes from the local memory 2817. The 
source operands needed for address generation are read from the GPR file 2801. 
Load data is read from the local memory 2817 and written to the GPR file 2801 or 
the VR file 2802 for scalar and vector store instructions. Store data is read from the 
GPR file 2801 or VR file 2802 for scalar and vector load instructions and written to 
the local memory 2817. The LSU 2816 also executes DMA reading and writing 
instructions between the local memory 2817 and the main memory, such as memory 
1203 of Figure 2, and between the main memory and the look-up table within the 
VLUT2811 

[00185] The vector permute unit (VPU) 2808 executes the vector permute 
instructions and variations and vector byte shift/rotate instructions. Source and 
destination data is accessed from the VR file 2802. The vector simple integer unit 
(VSIU) 2809 executes vector addition, subtraction and bit shifting instructions, etc., 
operating on byte, half-word and word format. All sources and destinations are 
accessed from the VR file 2802. The vector complex integer unit (VCIU) 2810 
executes vector multiplication, multiplication-addition, and summation (e.g., 
addition of more than two values) instructions. Most operations are performed on 
byte, half-word, and word format. All source and destinations are accessed from the 
VR file 2802. The FPU 2807 and VFPU 2812 are provided for high precision 
processing of media data. 

[00186] The vector look-up table unit (VLUT) 28 1 1 executes the variable 
length decoding instructions and the look-up table read and writes instructions. The 
VLUT 281 1 can be used to advantageously map a vector of values into another 
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vector of values, based on a look-up table. The VLUT 281 1 provides efficient table 
look-up for a vector of data values to be mapped using a single look-up table or 
multiple look-up tables. The VLUT also supports various sizes of look-up indices 
and table entries. There are several look-up modes available. All sources and 
destinations are accessed from the VR file 2802. 

[00187] The instruction/branch unit 2821 contains all the functions for 
handling instruction control and dispatch. It contains the program counter and the 
branch unit for determining where to fetch the next instructions. The instruction unit 
2821 also contains an instruction cache memory 2820 for buffering the instruction 
from the main memory. The instruction unit 2821 further may contain a set of 
memory-mapped registers accessible from the host processor for starting and 
stopping the compute engine 2800. The instruction unit 2821 receives the 
instruction stream from the I/O interface 2822 and stores the instruction stream data 
in the instruction cache 2820. The instruction dispatcher 2819 then decodes the 
instruction stream according to an instruction priority scheme and dispatches the 
instructions to the corresponding functional units. 

[00188] The compute engine 2800 also includes an input and output (I/O) 
interface block 2822. The I/O interface handles requests for data to and from system 
memory and I/O space for instruction cache fills, local memory reads and writes, 
look-up table fills, and command fetches. The I/O interface also handles the 
requests from the host processor and other compute engines for accessing the 
compute engine's control registers and local memory. 
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[00189] The general purpose register file (GPR) 2801 has multiple entries to 
hold source operands and destinations for the IALU 2805, ISHU 2806, and the scalar 
load/store instructions, and the address sources for vector load/store unit (LSU) 2816 
instructions. In one embodiment, the GPR 2801 is 32-entry by 32-bit file, and it has 
six read ports and two write ports. In another embodiment, the GPR 2801 also holds 
the source operands and destinations for FPU 2807. Other configurations of the 
GPR may exist. 

[00190] The vector register file (VR) 2802 has multiple entries to hold source 
operands and destinations for the VPU 2808, VSIU 2809, VCIU 2810, VLUT 2811, 
and vector load/store unit (LSU) 2816 instructions. In one embodiment, the VR 
2802 is a 32-entry by 128-bit file, and it has six read ports and two write ports. In 
another embodiment, the VR 2802 also holds the source operands and destinations 
for VFPU 2812. Other configurations of the VR may exist. 
[00191] The scalar processing units 2805-2807 read the inputs from the GPR 
2801. The locations of the GPR 2801 are selected by the register selector 2803. The 
scalar processing units 2805-2807 also write the outputs to the GPR 2801. The 
locations of the GPR 2801 are selected by the destination selector 2813. Similarly, 
the vector processing units 2808-2812 read the inputs from the VR 2802. The 
locations of the VR 2802 are selected by the register selector 2804. The vector 
processing units 2808-2812 also write the outputs to the VR 2802. The locations of 
the VR 2802 are selected by the destination selector 2814. 
[00192] In another embodiment, the compute engine 2800 may include a 
direct memory access (DMA) controller 2818 providing streaming access to and 
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from the local memory 2817 and the host memory such as the host memory 1512 of 
Figure 5B. The DMA controller 2818 is responsible to transfer data between the 
host memory and the local memory 2816, The DMA 2818 may also transfer data of 
a look-up table from the host memory to a look-up table memory in the VLUT 281 1. 
The DMA operation can be operated autonomously and asynchronously to the host 
processor, or the compute engine in the media processor. 
[00193] The compute engine 2800 may further include a special purpose 
register (SPR) file 2815. The SPR file 2815 contains multiple registers storing 
specific information about some transactions, for example, command queue 
instruction pointer (CIP). Other registers store miscellaneous information such as 
version information of the compute engine. 

[00194] Figure 19A shows an example of an instruction unit used by one 
embodiment of the present invention. Referring to Figure 19A, the instruction unit 
2900 of Figure 19A includes a command controller 2907. The command controller 
2907 provides the command instruction pointer (CIP), the command data pointer 
(CDP) of the instructions and data from a command queue, which is further 
described below, through the I/O interface 2908. The branch unit 2906 controls the 
instructions or routines whether the instructions should be branched. The 
instructions are then fetched from the main memory into instruction caches 2901. 
The instruction caches 2901 include an instruction cache tag ram 2903 and data rams 
2904. The instruction cache control 2905 generates a control signal to the cache 
memory in order to update instruction cache tag and data rams during the refills. 
The instruction cache control 2905 also issues cache refill requests to the stream 
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interface of the compute engine, through the I/O interface 2908, because of the 
instruction cache miss or an instruction of instruction stream touch command. 
[00195] The instruction caches (ICache) 2901 include an ICache tag ram and 
an ICache data ram. In one embodiment, ICache tag ram 2903 contains 64 entries. 
Each entry of the ICache tag ram contains 20 bits; there are 19 bits of tag and one bit 
for valid flag. Bits [19:24] of the program counter (PC) register are used to address 
one of the 64 entries in the ICache tag ram 2903. If the entry is valid and the 19 bits 
of the ICache tag match to 19 most significant bits of the PC register, the ICache hit 
is considered and the corresponding ICache data are sent to the instruction dispatcher 
2902, from the ICache data ram 2904. The ICache tag memory 2903 contains a 
virtual address for mapped instruction fetches or a physical address for unmapped 
instruction fetches. ICache may be direct mapped and may occupy 8K bytes of 
address space (64 entries of 128 bytes, 32 instructions each). Instructions that are 
exactly 64 lines apart from each other may be mapped to the same cache entry. The 
ICache is filled one line at a time. A line size may be 128 bytes or 32 instructions. 
When an instruction fetch generates a miss (e.g., ICache tag does not match or 
ICache tag is invalid), the corresponding line is fetched from the memory and the 
ICache tag and valid bit will be updated. When the "instruction stream touch" 
command is issued, more than one sequential line can be fetched from the memory. 
The software may issue the instruction stream touch command and specify the 
number of lines to be fetched, 

[00196] The program counter (PC) register is maintained by the branch unit 
2906. The PC register is used to access the ICache. The PC register selects the 
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cache line and compares with the ICache tag. The instruction dispatcher 2902 
receives the instructions from the ICache data memory 2904 and dispatches the 
instructions to appropriate functional units 2909 - 2916. The instruction dispatcher 
2902 dispatches the instructions based on a programmable priority scheme, which is 
described further below. 

[00197] Figure 19B shows another embodiment of an instruction unit. 
Referring to Figure 19B, the instruction unit receives instruction stream from the 
I/O interface through DMA operation to the instruction cache memory 2951. Then 
the instructions are stored in instruction registers 2952 to be analyzed by the branch 
decoder/address generator 2957. The branch decoder detects the branch condition 
based on the priorities of the instructions and their latencies information when 
executed. Once the branch decoder detects the branch conditions, the branch 
decoder instructs the program counter to update the address in which the next 
instruction should be fetched. The instruction unit also includes an instruction 
decoder 2958 to receive instructions from either instruction registers 2952 or the 
instruction buffers 2953, and construct an instruction group based on their priorities. 
The dispatch controller 2959 then instructs the destination selector 2954 to select the 
designated function units 2955 to execute the instruction group. The instruction 
decoder 2958 also detects when additional stalling cycle should be in placed. When 
the instruction fetching is stalled, the instructions pending to be executed may be 
stored in the instruction buffers 2953, until the previous instructions have been fully 
executed and the instruction fetching resumes. 
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[00198] Figure 20A shows a method of constructing a command queue in the 
main memory. An application software or a system software executed by the host 
constructs 3001 an instruction stream containing multiple instructions. The host 
then defines 3002 an area as a command queue in the host main memory. The host 
then writes 3003 the starting address of the next command stored in the command 
queue, into a command queue attribute (CQA) register of the compute engine that 
executes the instructions. In one embodiment, the host writes to the CQA register of 
the compute engine through a set of memory-mapped addresses. Next, the host 
writes 3004 the command into the command queue in the main memory. A 
command consists of an instruction priority and pointer corresponding data pointer. 
The host then updates 3005 the command current number produced (CNP) register, 
which in turn notify the compute engine that there is a new command available to be 
fetched. 

[00199] On the other hand, as shown in Figure 20B, the compute engine that 
receives and executes the instructions is notified 3010 by the host that a new 
command is ready to be fetched. Referring to Figure 20B, the compute engine 
compares 3011 the current number produced (CNP) register with the current number 
consumed (CNC) register to determine if there is a new command entered in the 
command queue. If the CNP is matched with the CNC, there is no new command 
entered in the command queue. Thus the compute engine enters into idle and 
waiting for the next command. If the CNP does not match the CNC, it means a new 
command has been entered in the command queue. The compute engine then 
retrieves 3013 the start address and the size of the command from the CQA register 
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and the CNC. Then the command is fetched 3013 from the main memory based on 
the starting address and the size of the command queue calculated from the CQA 
register. In one embodiment, the command fetch may be through an address 
mapping scheme, such as the video address re-mapping table (VART) 1515 of 
Figure 5B. Such memory access may be through a coherent interface such as the 
coherent interface 1513 of Figure 5B, or a non-coherent interface such as the non- 
coherent interface 1514 of Figure 5B. Next, the memory access is checked 3014 
whether a memory access violation occurs. If there is a violation as result of the 
memory mapping (e.g., through VART), an error message is generated 3019, by 
issuing an exception through an interrupt mechanism. If no memory access violation 
occurred, the instruction pointer is loaded into the command instruction pointer 
(CIP) register in operation 3015. The instruction pointer value of CIP register in 
turn is loaded into the program counter (PC) register and the data pointer value of 
CDP register is loaded into the general-purpose register (GPR), in operation 3016. 
Then the instructions are fetched 3017 from the main memory into the instruction 
caches, based on the instruction pointer and data pointer values loaded in CIP and 
CDP registers. After the instructions have been fetched from the main memory, the 
CNC register is updated 3018 until an end of command (EOC) is received. The 
instruction fetching continues until the values in CNC and CNP are matched, in 
which case, there are no more new commands or instructions available in the 
command queue. In such cases, the instruction unit goes into idle stage until the 
CNC and CNP does not match, in which case, the instruction unit starts a new 
instruction fetching again. 
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[00200] Two counters are provided in a compute engine to keep track of the 
number of commands produced by the host and consumed by the compute engine: 
the command queue number produced (CNP) and command queue number 
consumed (CNC). The CNP and CNC are 16-bit registers each, as shown as 3220 of 
Figure 22. The host has access to CNP for updating whenever it adds commands to 
the command queue. The compute engine increments the CNC when a command is 
fetched. Whenever the CNP and CNC are not equal, there are commands in the 
command queue waiting to be processed. The host reads the CNC register to 
determine the progress a compute engine has made on the commands in the queue 
and to determine the space left in the command queue. The host accesses the CNP 
and CNC as memory-mapped registers. They can be accessed individually with the 
format shown in 3220 of Figure 22, or together for controlling the stopping and 
starting of command processing for command queue switching, which is described 
further below. The low order bits of the CNC are used as an index into the 
command queue. These bits concatenated with the command queue starting address 
(CQS A) bits form the address from which the next command will be fetched. Table 
3230 of Figure 22 shows that the starting address of the next command queue 
address 3233 is formed by the CQS A and CNC registers. The number of bits taken 
from the CNC and CQS A registers depends on the size based on the command 
queue size code (CQSZ). Each CQSZ code 3231 has a corresponding size in bytes 
such as 3232. 

[00201] The compute engine interacts with host system by being sent a series 
of commands (e.g., subroutines) from the host. A queue of these commands is set 



04860.P2687 



61 



up in memory and the compute engine is directed to this command queue (CQ) 
through a set of control registers accessible through memory-mapped addresses. 
Figure 21 shows an example of an embodiment of the architecture of a command 
queue used in an aspect of the present invention. Referring to Figures 21 and 22, 
the command queue 3 109 is defined by the host system in the main memory 3 107. 
Each command, such as command 3108, consists of two 32-bit words aligned on a 
double word boundary. The first word is the command instruction address pointer 
(CIP) 3201 pointing to a location of the command code library 3111. The second 
word is the command data address pointer (CDP) 3203 and 3112 pointing to a 
location of the command data parameters section 3110. The CEP is the starting 
address of instructions executed by a compute engine for this command such as 
command 3108. When the command is executed, instruction fetching begins at the 
location pointed by the CIP. The CIP word also contains a invalidate (IV) bit 3202. 
If the IV bit has a logical value one, the instruction cache is flushed before the 
command being executed. The CDP 3203 is a general-purpose 32-bit data being 
used by the command. In one embodiment, it could be used as an address to the data 
section in the memory such as data section 3 1 12 for this command. The data section 
is where typical arguments for this command (e.g., pointers to data, block addresses, 
number of blocks, etc.) would reside. 

[00202] Each compute engine receives commands from a separate main 
memory based circular queue. The command queue start address and size is 
determined by the driver and communicated to a compute engine by writing into its 
command queue attribute register (CQA), as shown as 3210 of Figure 22. Referring 
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to Figure 22, the CQA contains a 24-bit starting address CQSA 3211, and a 3-bit 
code 3212 specifying the size of the command queue (CQSZ). The size of the queue 
is limited to power of two starting at 256 bytes (e.g., 32 commands) and ending at 
4096 bytes (e.g., 512 commands). The starting address may be aligned on the 
boundary specified by the queue size. The CQA register is accessible as a special 
purpose register (SPR). 

[00203] Referring to Figure 21, when the host 3101 generates a command 
queue, it writes the starting address and size of the command queue to a command 
queue attribute (CQA) register 3102 of a compute engine that will execute the 
command, through a set of memory-mapped addresses. The host then writes the 
command into the command queue 3109, at a location such as command 3108. It 
next updates the command current number produced (CNP) register 3104, which in 
turn notifies the compute engine that there is a new command available in the 
command queue 3109. When the value in the CNP 3104 does not match the one in 
current number consumed (CNC) register 3103, the compute engine calculates the 
next command starting address 3105 in the command queue and fetches the 
command out of the command queue based on the calculated address such as address 
3110. The command 3110 contains a CIP and CDP value. The CIP value is loaded 
into the CIP register 3113 and the CDP value is loaded into the CDP register 31 16. 
The CIP register is pointing to the command code library 3 1 1 1 and the CDP register 
is pointing to the command data section 3112. The CIP value is then loaded into the 
program counter (PC) register 3114 and the instructions are fetched into the 
instruction caches 3115. The CDP value can be moved to the general purpose 
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register (GPR) 31 17 where it can be used, for example, as a base register to access 
data parameters associated with the command. When the command has been 
executed, as indicated by an end of command (EOC) instruction, CNC is 
incremented and the CNC 3103 and CNP 3104 registers are again compared to 
determine if there are more commands to process. If a command fetching results in 
a memory access violation, such as one from the VART, the memory access 
exception is thrown through an interrupt mechanism and the command fetching is 
stopped. 

[00204] Command queue switching is defined as the process of switching 
from executing commands from one queue to executing commands from another 
queue. Switching between command queues can only occur at command 
boundaries. This can be accomplished by changing the location of the command 
queue by updating the CQA register. During the transaction between executing 
commands from one queue and switching to another, a special memory-mapped read 
of the command counters (CQCNTRS) may be used. The read returns the current 
values of the CNP and CNC registers and also clears the CNP and CNC registers. It 
also causes the compute engine to stop fetching commands when the current 
command has completed, since the CNP and CNC are equal. Once the CNP and 
CNC are cleared, the host can modify the CQA and then update the CNP and 
possible CNC. When the current command has completed, the next command is 
fetched using the new queue attributes. CQCNTRS is a 32-bit register, wherein 
higher 16 bits contain CNC and lower 16 bits contain CNP. 
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[00205] The instruction stream used in the present invention is made up of 
instruction groups. In one embodiment, an instruction group contains up to four 
instructions. Each instruction is assigned a corresponding priority number. This 
feature greatly improves the usability of the instruction caches over a convention 
very long instruction word (VLIW) dispatching. In a conventional VIIW type of 
processor implementation, the approach to specifying the instructions in memory 
and the cache is to align the four 32-bit operations on 128-bit memory boundaries. 
Full 128-bit wide instructions are then issued on each cycle with the four 32-bit 
operations being sent to four execution units every cycle. If four operations are not 
available to be issued every cycle then a no-operation (NOOP) operations are sent to 
the execution units. These NOOP operations take up a 32-bit operation slot and 
cause the code to become long and the instruction cache efficiency to be low. 
[00206] Unlike the conventional approach, the present invention assigns each 
instruction a corresponding priority number based on the functional unit to which it 
belongs. Figure 23 shows an example of a table 3300 that defines the priorities for 
the instructions executed in each functional unit, the branch instruction is dispatched 
earlier than any other instructions. The integer arithmetic/logical (IALU) unit 3301 
has the lowest priority. Other configurations may exist. 
[00207] The instructions in the present invention are packed into a group. 
When the group is completed, the group along with all instructions in the group is 
dispatched in the same cycle. The instruction group is considered completed, if one 
of the following two conditions occurs: 
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If the next instruction in the stream has a instruction order ID number equal 
or lower then the current one; or 

If the current instruction group contains up to a predetermined number of 
instructions. 

[00208] In one embodiment, the predetermined number of instructions can be 
up to four instructions. The above conditions are based on the assumption that there 
are no more than one functional units of a land in a compute engine. In another 
embodiment, there may be more than one functional units of a kind, in which case, 
more than one instruction with the same priority are allowed, as long as the number 
of instructions with the same priority does not exceed the number of the functional 
units of the same kind. The branch unit instruction that will execute as a no- 
operation is defined to insure that if the two conditions above are not met, the no- 
operation (NOOP) instruction must be used to force one of the conditions. As an 
example, consider the following code: 

Group 1: { ADD, LW, VPERM, VADD } 

Group 2: { SUB, STW } 

Group 3: { VPERM } 
The VPERM (vector permute) instruction in Group 3 wants to be issued in a cycle 
after Group 2. However, since the priority of VPERM is higher than the STW 
instruction in Group 2, the VPERM will be dispatched in Group 2. To force the 
VPERM into Group 3, a NOOP instruction is needed as following: 

Group 1: { ADD, LW, VPERM, VADD } 

Group 2: { SUB, SLW, NOOP } 
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Group 3: { VPERM } 
[00209] Figure 24 shows a method used in one embodiment of the present 
invention to dispatch instructions in groups. The method starts with a new 
instruction group in 3401. When an instruction is received 3402, the instruction unit 
checks 3403 whether the current instruction group is completed. If the current 
instruction group is completed, the instruction group is dispatched 3404 and the new 
instruction will be dispatched in the next group. If the current instruction group is 
not completed, the new instruction is added 3405 to the current instruction group. 
[00210] Figure 25 shows a method used in one embodiment of the present 
invention to complete an instruction group. When a new instruction is received in 
3501, the instruction unit checks 3502 if the new instruction has equal or lower 
priority than the current instruction in the group. If the new instruction has equal or 
lower order ID number than the current instruction in the group, the group is 
dispatched 3504 and the new instruction is added into the next instruction group. If 
the new instruction has higher order ID number than the current instruction in the 
group, it is added to the current group. The current instruction group is then checked 
if the number of instructions in the group is equal to a predetermined number of 
instructions (e.g., four instructions). If so, the current group is dispatched 3504, 
otherwise, a next instruction from the instruction stream is fetched to complete the 
current instruction group. 

[00211] The goal of the instruction priority scheme provided by the present 
invention is to reduce the size of the code. However, it is not expected that there are 
always four instructions issued on each clock cycle due to many reasons, such as 
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resource conflicts, or unavailability of the previous results. The instruction priority 
scheme of the present invention is able to compress the code into a small one. For 
example, assuming the following operation is performed: vector A and vector B are 
added and result is written into C. The vectors A and B need to be loaded from local 
memory such as local memory 2817 of Figure 18 into registers v4 and v5 of VR 
2802. The result needs to be written into register v6. Following sequences of 
operations will be performed: 

Cycle 1 : Load vector A into v4 

Cycle 2: Load vector B into v5 

Cycle 3 : Wait for results of load operations 

Cycle 4: Wait, result of first load is available, but not the second one 
Cycle 5: Perform vector addition 
Cycle 6: Wait for result of vector addition 
Cycle 7: Result of vector addition is available, store into C 
The code will have the following instructions: 

<load_vector> <load_vector> <noop> <noop> <noop> <vector_add> 
<noop> <noop> <store_vector> 
The instruction dispatch unit will break it down into the following instruction 
groups: 

Group 1: <load_vector> 
Group 2: <load_vector> <noop> 
Group 3: <noop> 
Group 4: <noop> 
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Group 5: <vector_add> <noop> 

Group 6: <noop> 

Group 7: <store_vector> 
The <noop> in Group 2 will force a new instruction group, Group 3. 
[00212] The compute engine of the present invention is designed so that 
instructions within an instruction group are dispatched on the same cycle. However, 
there is no guarantee of the number of cycles (due to instruction cache stalling, 
branch stalling, etc.) that can occur between instruction groups. Each instruction 
executed in a functional unit has a latency. The resources being used by an 
instruction are considered as in-use and are not available for another instruction until 
the resources become available. The destination target address for an instruction is 
considered to be in-use from the cycle after the instruction is issued until the cycle 
before its latency number. A non-branch unit instruction may not be issued until the 
sources that the instruction specifies and the target destinations are not in-use. Since 
the number of cycles due to stalling is unknown, enough instruction groups must be 
issued to avoid the resource conflicts, even if the instruction group just contains a 
NOOP instruction. When a stall in the instruction pipeline occurs, there may be a 
potential for destination bus conflicts going to the GPR and VR, the hardware 
detects these conditions and inserts additional stall cycles to insure the correct 
operation without conflicts. 

[00213] The latency of an operation is defined as the number of cycles before 
an instruction can be dispatched that uses the results of a previous operation. The 
dispatch rate indicates how many delay cycles are needed before an instruction can 
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be issued to the same functional unit. The table 3600 in Figure 26 shows an 
example of the latency and dispatch rate corresponding to each functional unit with 
different instructions. A value of one of the dispatch rate indicates the instruction 
can be issued on the next cycle. The latencies of the functional units are operation 
dependent. In one embodiment, the latencies of the operations on a particular 
functional unit may be the same. 

[00214] The branch unit instructions are dispatched and executed earlier than 
other units so that the flow of instructions to the other units is not broken. The 
hardware keeps track of resources being used or altered by the non-branch 
instructions. The hardware stalls the execution of a branch unit instruction if the 
resources required by the branch instruction are in-use by the non-branch 
instructions, until the resources are available. Thus, the branch instruction may not 
be in the same instruction group with an instruction that uses or alters a resource 
required by the branch instruction. A branch instruction may be placed in the next 
instruction group following the altering instruction. For optimal performance, a 
branch instruction may be placed far enough after the altering instructions so that 
other instructions can be executed instead of stalling the dispatching. The branch 
dependent latency is defined as the latency between the altering instruction and the 
affected branch instruction. In one embodiment, the branch dependent latency is 
defined as the sum of the latency of the altering instruction plus five. 
[00215] Figure 27 shows a method of dispatching a non-branch unit 
instruction. When a non-branch instruction is received 3701, the source operand 
registers required by the instruction are checked 3701 whether such resources are in- 
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use by other instructions. If the source resources are in-use, an instruction stall 
occurs in operation 3707. If the source resources are available, the target destination 
registers required by the instruction are checked 3703 whether such resources are in- 
use by other instructions. If the target destination resources are in-use, a stall occurs. 
If both source and target destination resources are available, the availability of the 
functional unit is checked if it is available (e.g., issue rate is less than allowed 
request rate) for instruction being dispatched. Otherwise stalling is continued. 
[00216] Figure 28 shows a method used to dispatch a branch unit instruction 
in an embodiment of the present invention. When a branch instruction is received 
3801, all of the resources required by the branch instruction are checked 3802 
whether such resources are in-use or altered by other non-branch instructions. If the 
resources are available, the branch instruction is dispatched 3806. If the resources 
required by the branch instruction are in-use or altered by other non-branch 
instructions, an instruction stall occurs until the resources become available. In one 
embodiment, such resources may include the condition register, link register, counter 
register, and the instruction cache control register. 

[00217] Source resources are corresponding to input operands and the 
destination resources are corresponding to output operands. For example, for an 
instruction of "add rl, r2, r3", which is corresponding to "rl = (r2 + r3)", rl is the 
destination and r2 and r3 are the sources. When the instruction is issued, rl is 
marked "in-use". Assuming that the latency of add instruction is two clock cycles, 
consider the following codes: 

add rl, r2, r3 /* rl = (r2 + r3) */ 
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subf r5 , r4, rl /* r5 = (rl - r4) */ 

Since rl will be "in-use" in the first instruction, when subf is encountered, the 
instruction dispatch unit will stall until rl, used by the first instruction, is no longer 
in-use. Similarly, a stall will occur in the following codes: 

addrl,r2,r3 /* rl = (r2 + r3) */ 

subf rl , r4, r5 /* r 1 = (r5 - r4) */ 

where rl is used in the first instruction and it will not be available for the second 
instruction, until rl is no longer in-use by the first instruction. A register is marked 
in-use by setting a state bit in the register. 

[00218] A compute engine can be interrupted from the host through a 
memory-mapped address. An interrupt is sent to the host after various exception 
conditions or through a software programmable interrupt. A compute engine can be 
interrupted through a memory-mapped read of its program counter (PC). This read 
causes a program counter exception to occur which causes instruction fetching to 
stop. Figure 29 shows an example of the PC register and state. The PC along with 
a most significant 2-bit state (PSt) is returned to the requesting host. Commands and 
instruction fetching would resume only after the host clears the exception condition. 
The PC register 3900 is a 30bit address pointing to the location where instruction 
execution would have continued if the exception did not occur. Table 3901 shows 
the PC states with corresponding descriptions. 

[00219] Individual compute engine interrupts and exceptions to the host are 
handled through the compute engine's interrupt register, as shown as register 4000 
of Figure 30. Referring to Figure 30, interrupt register 4000 contains exception 
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flags 4001-4003 and a software generated interrupt valid 4005 and code field 4004. 
The interrupt register bits [0:7] (VEOINT) contain the exception flags (e.g., IE 4001, 
PE 4002, and ME 4003) that are set due to various exception conditions. Table 4006 
shows an example of such conditions. When any of the exception flags are on, 
instruction fetching is disabled and the compute engine is put in a wait state. These 
bits may be read only and cannot be written from the host or the compute engine. 
The instruction code (ICODE) 4004 and valid (IV) fields 4005 are used to generate 
an interrupt from software to the host. The ICODE and IV bits can be read and 
written from the compute engine code. The method for a compute engine to 
generate an interrupt is a software convention. When the compute engine wants to 
generate an interrupt, it should first read the VEOINT register to see if there is an 
outstanding interrupt. If so, the compute engine should wait until the host has 
handled the previous interrupt. Otherwise, the VEOINT should be written with the 
VEOINT bit active (e.g., logical value of one) and the ICODE field reflecting the 
nature of the interrupt. The host will detect an interrupt through a dedicated signal 
coming from the media processor and reacts properly by invoking a special 
exception handler. Besides the individual compute engine interrupts/exceptions to 
the host, additional interrupts can be generated due to VART exceptions. 
[00220] Figure 31 shows a flow diagram illustrating the general steps used by a 
processor to manipulate data in executing an instruction according to one 
embodiment of the invention. In operation 5501, an instruction decoder (e.g., 
instruction dispatcher 2819 in Figure 18) receives an instruction (e.g., from 
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instruction cache 2820 in Figure 18) and decodes the instruction to determine the 
operations to be performed. 

[00221] In operation 5503, register files (e.g., register file 2801, vector register 
file 2802, special purpose register file 2815 in Figure 18) or memory (e.g., local 
memory 2817, or system memory 1412) are accessed to retrieve data required for the 
processing of the instruction. In this operation Direct Memory Access (DMA) 
controller (e.g., DMA controller 2818) may be used to transfer data from system 
memory. 

[00222] In operation 5505, the execution unit (e.g., Vector Simple Integer Unit 
(VSIU) 2809, Vector Look up Table Unit (VLUT) 281 1, or Vector Complex Integer 
Unit (VCIU) 2810) is enabled to perform the operation on the data accessed in 
operation 5503. The result is stored into the register file (e.g., vector register file 
2802) or into memory (e.g., local memory 2817, or system memory 1412) according 
to the requirements of the instruction. 

[00223] In one embodiment of the present invention, data to be processed are first 
loaded into local memory 2817. A vector of data is loaded into the vector register 
file before an instruction is executed. After the execution of an instruction is 
complete, the results stored in the vector register are transferred into the local 
memory 2817. 

[00224] At least one embodiment of the present invention seeks to compute the 
vector of absolute differences of two vectors of numbers (i.e., the absolute difference 
of the two vectors) by using a single instruction in an execution unit. 
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[00225] Figure 32 illustrates a block diagram representation of a circuit for the 
execution of a method to compute an absolute difference of two vectors of numbers 
according to one embodiment of the present invention. The vectors of numbers, vA 
and vB, are stored in two entries (5101 and 5102) of a vector register file. After the 
execution unit receives control information from the instruction dispatcher, entry 
selector 5105 selects the elements of the vectors from vA and vB. In one 
embodiment of the present invention, an entry of a vector register file (or, a vector 
register) contains 128 bit, which may contain 16 8-bit numbers, or 8 16-bit numbers, 
or 4 32-bit numbers. These numbers can be signed or unsigned. According to 
configuration 5110 specified by the instruction, entry selector 5105 fetches elements 
5121, 5122, 5129 of vector vA from entry 5101 and elements 5131, 5132, 
5139 of vector vB from entry 5102. These elements are processed by logic unit 5107 
to computer the absolute differences of the elements. Destination selector 5109 
outputs the result of the absolute differences into entry 5103 of the vector register 
file. 

[00226] Figure 33 illustrates a block diagram representation of a circuit for the 
execution of a method to compute an absolute difference of two numbers according 
to one embodiment of the present invention. Input numbers A and B are sent into 
execution unit 5200 to produce the absolute difference D=|A-B|. Invertors 5201 and 
5221 change the sign of the input numbers so that the adders 5203 and 5223 produce 
A-B and B-A. Logic unit 5215 generates a selection signal from the output of the 
adders 5203 and 5223, causing multiplexer 5213 to select a positive number from A- 
B and B-A. When logic unit 5217 determines that the selected result does not 
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overflow, multiplexer 5219 selects the output (|A-B|) from multiplexer 5213 as result 
D; otherwise, the multiplexer 5219 selects the saturated value (e.g., a value with all 
bits being set to 1) as result D. 

[00227] Logic unit 5215 examines the carryout of adder 5203. If there is a 
carryout, B is larger than A, and the selection signal generated by logic unit 5215 
selects the result from adder 5223; otherwise, A is larger than B, and the selection 
signal selects the result from adder 5203. 

[00228] For signed number, logic unit 5215 examines the sign bit (the most 
significant bit) of the output of adder 5223. If the sign bit is high, A is larger than B, 
and the selection signal generated by logic unit 5215 selects the result from adder 
5203; otherwise, B is larger than A, and the selection signal selects the result from 
adder 5223. 

[00229] For unsigned numbers, the absolute difference of two numbers is always 
less or equal to the larger one of the input numbers. Thus, there cannot be an 
overflow, and the operation will never saturate. 

[00230] For signed numbers, logic unit 5217 checks the results of both adders 
5203 and 5223. The carryout and carryin of the sign bit of each result are examined. 
If the carryout of the sign bit of one of the result is low and the carryin of the same 
bit is high, an overflow occurs. When an overflow is detected, logic unit 5217 
generates a signal to cause multiplexer 5219 to select a saturated value as result D. 
[00231] Figure 34 illustrates data representations for the execution of an 
instruction for the computation of absolute difference of two vectors of numbers 
according to one embodiment of the present invention. Instruction 5310 illustrates 
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the data representation in instruction vasubshs for the evaluation of the absolute 
difference of two vectors of numbers, each of which is a signed halfword (16 bits). 
Vector register file 5320 contains a number of entries (e.g., 32 entries). Each of the 
entry has 128 bits, which can hold 8 halfwords. Vectors vA, vB and vD, each having 
8 halfword numbers, are stored in three entries of the vector register file (i.e., 3 
vector registers). For example, the second number of vA, Al, is stored in bit 
segment 5321; the second number of vB, Bl, is stored in segment 5322; and the 
result, D1=|A1-B1|, is stored in segment 5323. The addresses of these entries for 
vectors vA, vB, and vD are specified in instruction 5310. Three 5-bit segments 5302, 
5303, and 5304 in instruction 5310 are used to encode the addresses of the entries in 
the vector register file for vectors vA, vB and vD. Segments 5301 and 5305 are used 
to encode the identification of the instruction. 

[00232] While Figure 34 illustrates an example in which each number is a 
halfword, other instructions can be implemented where each element of the vectors 
is a byte (8 bits), or a word (32 bits), etc. For example, when a register file with 128- 
bit entries is used, an absolute difference of vectors of 16 8-bit signed or unsigned 
numbers can be evaluated using a single instruction. The numbers can be signed or 
unsigned, integers or floating-point numbers. It will be apparent to one skilled in the 
art that instructions can also be implemented for register files with entries of more 
than 128 bits each, where more elements can be processed in a single instruction. 
[00233] Figure 35 shows a flow diagram for a method of computing the absolute 
difference of two vectors of numbers according to one embodiment of the present 
invention. In operation 5411, the execution unit receives two vectors of numbers 
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from a register file. Then, the execution unit simultaneously computes the absolute 
difference of the two input vectors of numbers in operation 5413. In operation 5414, 
the resulting vector that contains the absolute differences of the corresponding 
elements of the two vectors of numbers is stored in an entry of the register file. 
[00234] Figure 36 shows a flow diagram for a method of computing the absolute 
difference of two numbers according to one embodiment of the present invention. 
After receiving numbers A and B in operation 5601, operations 5602 and 5603 
evaluate A-B and B-A simultaneously. In operation 5605 a positive number is 
selected from A-B and B-A as |A-B|. Then, operation 5607 checks if overflow occurs 
during the evaluation of A-B and B-A. If an overflow is detected, a saturated value is 
selected as the result in operation 5611; otherwise, |A-B| is selected as the result. 
Operation 5613 outputs the result. The method illustrated in Figure 36 can be used 
for the evaluation of absolute difference of vectors of signed, unsigned, or floating 
point numbers. While Figure 36 shows a preferred embodiment, other embodiments 
may also be implemented. For example, in one embodiment, A-B is first evaluated. 
Then, the sign of the resulting number is examined. Then, -(A-B) is evaluated. If it is 
determined that A-B is negative, -(A-B) is selected as the result, otherwise, A-B is 
selected as the result. Note that the overflow detection (operations 5607, 5612 and 
5611) for saturation of results (e.g., operations 5607, 5612 and 5611) can be 
optional. 

[00235] One embodiment of the present invention is a code sequence to perform 
the Sum of Absolute Differences (SAD) of pixel data. A SAD of pixel data is a 
measure of the closeness of the attributes of two vectors of pixels. It is commonly 
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used in algorithms for image processing, such as for de-interlacing, motion 
estimation and pull down detection. The following code sequence loads vectors of 
pixel attributes from memory, computes the absolute difference of the vectors of 
pixel attributes, and sums up the absolute differences to produce a scalar measure, 
SAD. The blocks of 8-bit pixel attributes are stored line after line with 16 pixels per 
line. The scalar and vector units of a computer engine (e.g., computer engine 2800 in 
Figure 18) work in parallel. To compute the SAD, the Integer Arithmetic/Logic Unit 
(IALU 2805) increases the index for accessing the data in memory; the Load/Store 
Unit (LSU 2816) loads data from memory into vector resisters; the Vector Simple 
Integer Unit (VSIU 2809) produces a vector absolute differences; and the Vector 
Complex Integer Unit (VCIU 2810) sums the vector of absolute differences into 
SAD. 

[00236] Although the following code sequence illustrates only the computation of 
SAD for vectors of 16 pixels with 8-bit attributes, it will be apparent to one skilled 
in the art that this method may be used in computing SAD for vectors of various 
sizes and vectors of pixel attributes of various data sizes, and also for other 
applications such as iteratively solving large systems of equations and fitting a curve 
to a number of points in image reconstruction from projection data. 
[00237] In the following code sequence, rBase represents the pointer to the 
memory where the block of pixel attributes resides; rlndex is the index for accessing 
the current vector of 16 pixels; vO, vl, v2, and v3 are vectors of 8-bit pixel data; 
vZero represents a vector of zeros; and instructions saddi, Ivx, vasubub, vsum4ubs 
and vsumsws have single cycle latency. 
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{ saddi (rlndex, rlndex, 16) 

lvx ( vO, rBase, rlndex) 
} // group Al 

{ saddi (rlndex, rlndex, 16) 

lvx ( vl, rBase, rlndex) 
} // group A2 

{ saddi (rlndex, rlndex, 16) 
lvx ( v2, rBase, rlndex) 
vasubub ( v7 , vO , vl ) 

} // group A3 

{ saddi (rlndex, rlndex, 16) 
lvx ( v3, rBase, rlndex) 
vsum4ubs (v7 , v7 , vZero) 

} // group A4 



{ vasubub ( v8 , v2 , v3 ) 

vsumsws ( v7 , v7 , vZero ) 
} // group A5 



// IALU: increase rlndex by 16 
// LSU: load vO 



// IALU: increase rlndex by 16 
// LSU: load vl 



// IALU: increase rlndex by 16 

// LSU: load v2 

// VSIU: compute v7=|v0-vl| 



// IALU: increase rlndex by 16 
// LSU: load v3 
// VCIU: partial sum v7 of 
elements in v7 



// VSIU: compute v8=|v2-v3| 
// VCIU: sum elements of v7 



[00238] When instructions in group Al are executed, LSU loads the first vector of 
16 8-bit pixel data into vector register vO by executing the lvx instruction; and, by 
executing the saddi instruction, IALU increases rlndex by 16 so that rlndex points to 
the vector of next 16 8-bit pixel data, which will be loaded when the instructions in 
group A2 are executed. In group A2, LSU loads the second vector of pixel data into 
vector register vl; and IALU updates rlndex. In group A3, VSIU computes the 
absolute difference of vO and vl by executing the vasubub instruction; and LSU 
loads the third vector into vector register v2, while IALU updates rlndex. 
[00239] Instruction vsum4ubs partially sums a vector of data elements. For 
example, if vA contains 16 8-bit data elements 
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{vAO, vAl, vA2, vA3, vA4, vA5 , vA6, vA7, 
vA8, vA9, vAlO, vAll, vA12 , vAl3, VA14, vA15}, 



and vB contains 4 32-bit data elements 



{vBO, vBl, vB2, vB3}, 



the execution of instruction vsum4ubs(vD, vA, vB) produces vector vD which 
q contains 4 32-bit data elements 

JJj {vDO, vDl, vD2, vD3}, 

where 

M vD0= vB0+vA0+vAl+vA2+vA3; 

fU vDl= vBl+vA4+vA5+vA6+vA7; 

W vD2= vB2+vA8+vA9+vA10+vAll; and 

M vD3= vB3+vA12+vAl3+vAl4+vA15 . 

M 

[00240] In group A4, VCIU partially sums the 16 8-bit absolute differences stored 
in v7 into 4 32-bit partial sums by executing the vsum4ubs instruction. At the same 
time, the forth vector is loaded into v3 by LSU, and rlndex is updated again by 
IALU. 

[00241] Instruction vsumsws is used to sum a vector of data elements. For 
example, if vA contains 4 32-bit data elements 

{vAO, vAl, vA2, vA3}, 



and vB contains 4 32-bit data elements 
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{vBO, vBl, vB2, vB3}, 

vsumsws(vD, vA, vB) produces vD which contains 32-bit data elements 

{vDO, vDl, vD2, vD3}, 

where 

vD0= vB0+vA0+vAl+vA2+vA3 . 

[00242] In group A5, VSIU computes the absolute difference between v2 and v3; 
and, by executing the vsumsws instruction, VCIU produces the sum of absolute 
difference of vO and vl. 

[00243] In the above code sequence, a SAD is computed in 3 cycles in average, 
since updating indices and loading vectors of pixel attributes are done in parallel 
with the computations of the SAD. Thus, a method of computing a sum of absolute 
difference (SAD) according to an embodiment of the present invention is much more 
efficient than prior art methods. 

[00244] At least one embodiment of the present invention seeks to perform vector 
table look-up by using a single instruction in an execution unit. The execution unit 
has a bank of look-up memory, comprising a number of look-up units, which can be 
configured into a number of look-up tables in a fashion indicated by an instruction in 
order to simultaneously look up a vector of data elements. Each of the data elements 
is looked up from one of the look-up tables. A look-up unit will be understood to be 
a memory unit that can be individually addressed and accessed, independent of the 
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operations of the other memory units. A look-up unit can be used as a look-up table. 
However, in at least one embodiment of the present invention, a number of look-up 
units are combined to form a look-up table, according to the configuration specified 
by the instruction. 

[00245] Figure 37 illustrates a block diagram representation of a circuit for the 
execution of a method to perform table look-up of a vector of data elements 
according to one embodiment of the present invention. Entry 5701 in a vector 
register file contains a vector of indices, vB, for a vector look-up operation. After the 
execution unit receives control information for an instruction dispatcher, entry 
selector 5703 selects the indices from vB. In one embodiment of the present 
invention, an entry of a vector register file contains 128 bits, which may contain 16 
8-bit indices, or 8 16-bit indices. According to configuration 5710 specified by the 
instruction, entry selector 5703 fetches indices 5711, 5712, 5719 from entry 5701. 
These indices are used by look-up units 5705 to select the entries 5721, 5722, 
5729 from the look-up tables according to configuration 5710 specified by the 
instruction. Destination selector 5707 outputs the result of the vector look-up 
operation into entry 5702 of the vector register file. 

[00246] Figure 38 illustrates a block diagram representation of a circuit for 
configuring look-up units into different look-up tables according to one embodiment 
of the present invention. In one embodiment of the present invention, memory for 
the storage of entries of look-up tables, i.e., look-up memory, contains a number of 
look-up units. Each of the look-up units 5841 - 5844 (LUT0 - LUT3) contains 256 8- 
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bit entries. Each of indices 5801 - 5804 (AO - A3) is 8-bit. Thus, a single 8-bit index 
can be used to look up any element in a look-up unit. 

[00247] In one configuration as specified by configuration 5810, indices AO - A3 
are used independently in 4 look-up tables to look up for 4 entries 5811 -5814 (DO - 
D3). Look-up units LUTO - LUT3 are used as 4 look up tables. In this configuration, 
logic unit 5871 generates a selection signal causing multiplexer 5851, 5853, and 
5854 to select index AO (5801) for look-up unit LUTO (5841), A2 for LUT2, and A3 
for LUT3. Logic unit 5873 generates a selection signal causing multiplexer 5831, 
5832, 5833, and 5834 to select the result from LUTO to entry DO (5801), LUT1 to 
Dl, LUT2 to D2, and LUT3 to D3. Thus, 4 elements (DO - D3) are looked up 
simultaneously from 4 look-up tables using 4 8-bit indices (AO - Al) using a single 
instruction. Each of the look-up tables has 256 8-bit entries, 
[00248] In another configuration (5810) specified by an instruction, look-up units 
LUTO - LUT3 are combined into a single table with 512 16-bit entries. LUTO and 
LUT1 contain the upper and lower 8 bits of the first 256 entries; LUT2 and LUT3 
contain the upper and lower 8 bits of the rest of the entries. In this case, 9-bit indices 
are necessary in order to look up an arbitrary located element from a table. AO and 
Al are combined to store a 9-bit index, where Al (5802) contains the lower 8 bits of 
the index, and AO contains the remaining bits. Logic unit 5871 generates a signal 
causing multiplexer 5851, 5853, and 5854 to select bits in Al to be used in look-up 
units LUTO, LUT2, and LUT3. Logic unit 5873 generates a selection signal causing 
multiplexers 5831, 5832, 5833, and 5834 to select the results from LUTO and LUT1 
to DO and Dl when the index bit in AO is 0, and to select the results from LUT2 and 
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LUT3 to DO and Dl when the index bit in AO is 1. Zero is selected for D3 and D4. 
Thus, a 9-bit index stored in AO and Al can be used to look up an entry in a table of 
512 16-bit entries. The result of the look-up operation is stored in DO and Dl; and 
the 4 look-up units LUTO - LUT3 are combined into a single look-up table. It will be 
appreciated that a number of units as shown in Figure 38 may be used in order to 
look up simultaneously a vector of data elements. For example, when 4 units of 
those shown in Figure 38 is used, a vector of 16 8-bit elements can be looked up 
simultaneously from 16 256-entry tables in one configuration; and a vector of 4 16- 
bit elements can be looked up simultaneously from 4 512-entry tables in another 
configuration. 

[00249] Figure 39 illustrates another block diagram representation of a circuit for 
configuring look-up units into different look-up tables according to one embodiment 
of the present invention. In one configuration, 8 look-up units LUTO - LUT7 are 
used as 8 independent look-up tables, each of which contains 256 8-bit entries. Eight 
8-bit indices AO - A7 are used to simultaneously look up 8 16-bit entries into DO - 
D8, each from a corresponding look-up table. 

[00250] In another configuration, look-up units LUTO - LUT7 are used as 2 
independent look-up tables, each of which contains 512 16-bit entries. LUTO and 
LUT1 contain the upper and lower 8 bits of the first 256 entries of the first table; and 
LUT2 and LUT3 contain the upper and lower 8 bits of the rest of the entries of the 
first table. Similarly, LUT4 - LUT7 contain the entries of the second table. Two 9-bit 
indices stored in AO - A7 are used to select 2 16-bit entries into DO - D7. For 
example, in one configuration, the first index is stored in AO and Al, and the second 
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index is store in A4 and A5, where the lower 8 bits of the first and second indices 
are stored in Al and A5. According to configuration 5910, logic unit 5971 generates 
a control signal causing the multiplexers (e.g., 5931, 5938) to select Al for LUTO - 
LUT3 and A5 for LUT4 - LUT7. According to configuration 5910 and the bits in AO 
and A4, logic unit 5973 generates signals causing the multiplexers (e.g., 5941, 5948) 
to select look-up results from LUTO - LUT7 into DO - D7. For instance, when A4 is 
0, the results from LUT4 and LUT5 are selected into D4 and D5, and zero is selected 
into D6 and D7; when A4 is 1, the results from LUT6 and LUT7 are selected into D4 
and D5, and zero is selected into D6 and D7. Similarly, the first index can be stored 
in A2 and A3, and the second index can be stored in A6 and A7, where the lower 8 
bits of the first and second indices are stored in A3 and A7. Two 16-bit results of the 
look-up operation can be stored in D2, D3, D6, and D7. Thus, two 9-bit indices can 
be used to simultaneously look up two 16-bit entries from two 512-entry tables. 
[00251] In another configuration, look-up units LUTO - LUT7 are used as a single 
look-up table containing 1024 16-bit entries. LUTO and LUT1 contain the upper and 
lower 8 bits of entries 1-256; LUT2 and LUT3 contain entries 257-512; LUT4 and 
LUT5 contain entries 512-768; and LUT6 and LUT7 contain entries 769-1024. A 
10-bit index is stored in AO - A7 to select a 16-bit data from the table into DO - D7. 
For example, the lower 8 bit of the index is stored in Al, and the rest of the bits are 
stored in AO. Logic unit 5971 generates a selection signal causing the multiplexers to 
select Al for LUTO - LUT7. Logic unit 5973 selects zero into D2 - D7, and selects a 
result from LUTO - LUT7 into DO and Dl according to the index bits in AO. Thus, a 
10-bit index can be used to look up a 16-bit entry from a 1024-entry table. It will be 
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appreciated that if a vector register has 128 bits, two units as shown in Figure 39 
may be used to simultaneously look up a vector of 16 8-bit elements from 16 256- 
entry tables in one configuration; a vector of 4 16-bit elements from 4 512-entry 
tables in another configuration; and a vector of 2 16-bit elements from 2 1024-entry 
tables in another configuration. 

[00252] Figure 38 - 39 illustrates two examples of circuits for dynamically 
configuring look-up units into a number of look-up tables according to a 
configuration signal. It will be apparent to one skilled in the art that the method 
illustrated in Figure 38 - 39 can be used for designing circuits where the look-up 
units have a different size, or where there are a different number of look-up units, or 
where there are different combinations of configurations. 
[00253] Figure 40 illustrates data representations for the execution of an 
instruction for performing table look-up of a vector of data elements according to 
one embodiment of the present invention. Instruction 6010 illustrates the data 
representation in instruction vlut9al for looking up a vector of 4 16-bit data from 4 
512-entry look-up tables using 4 9-bit indices. Vector register file 6020 contains a 
number of entries (e.g., 32 entries). Each of the entry has 128 bits, which can hold 8 
halfwords. Vectors vB and vD, each having 8 halfword numbers, are stored in two 
entries of the vector register file. The four 9-bit indices (Bl, B3, B5, B7) are stored 
in bit segments 6021, 6022, 6023 and 6024 in an entry for vB. The address of vB is 
specified in bit segment 6004 in instruction 6010. The entries of the look-up tables 
6031 - 6034 (TAB0 - TAB3) are pre-loaded into look-up units before the execution 
of the instruction. In one embodiment of the present invention, 16 look-up units are 
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configured into look-up tables TABO - TAB3 according to the instruction. Each of 
16 look-up units contains 256 8-bit entries. During the execution of the instruction, 
table entries 6041 - 6044 are selected and stored in bit segments 6026, 6027, 6028, 
and 6029 of an entry vD in the vector register file. The address of vD in the vector 
register file is specified by bit segment 6002 in instruction 6010. Bit segments 6001, 
6004, and 6005 specify the identity of the instruction, including the configuration for 
the look-up tables. Thus, four data elements can be looked up simultaneously from 
four different tables of 512 16-bit entries using a single instruction, vlut9al. 
[00254] While Figure 40 illustrates an example in which each index has 9 bits 
and each table has 512 16-bit entries, other instructions can be implemented where 
each index has 8 bits, or 10 bits, and each table has 256 8-bit entries, or 1024 16-bit 
entries, or others. It will be apparent to one skilled in the art that instructions can 
also be implemented for register files where each entry has more than 128 bits, and 
where the look-up units have more memory capacities, such that more look-up 
operations may be performed simultaneously in a single instruction. 
[00255] Figures 41 - 43 illustrate block diagram representations of circuits for 
performing table look-up of vectors of different sizes using a set of look up units 
according to one embodiment of the present invention. Figure 41 shows a 
configuration where 16 8-bit indices are used in 16 look-up units to simultaneously 
look up 16 8-bit data using a single instruction. For example, index B0 (6101) is 
used in LUT0 (61 1 1), used as a table of 256 8-bit entries, to look-up an entry and 
store it in DO (6121). 
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[00256] Figure 42 shows a configuration where 4 9-bit indices are used in 16 
look-up units to simultaneously look up four 16-bit data using a single instruction. 
For example, an index is stored in BO and Bl (6201 and 6202). Bl contains the 
lower 8-bits of the index; and BO contains the remaining bit. Bl is used to look up 
data in look-up units 6231 - 6234 (LUTO - LUT3). Two successive look-up units ai 
combined for storing the lower and higher 8-bit bit segments of table entries. For 
example, an entry in LUTO contains the higher 8 bits of a 16-bit table entry; a 
corresponding entry in LUT1 contains the lower 8 bits of the 16-bit table entry; and 
these two entries from LUTO and LUT1 can be combined to represent the 16-bit 
table entry. Multiplexer 6221 selects a result from the output of LUTO - LUT3 into 
DO and Dl (621 1 and 6212), depending the state of the index bit in BO. Dl contains 
the lower 8 bits of the result; and DO contains the higher 8 bits of the result. When 
BO is 0, the index is in the range of 0 to 255, and the results from LUTO and LUT1 
are selected; otherwise, the index is in the range of 256 - 51 1, and the results from 
LUT2 and LUT3 are selected. LUT1 and LUT3 contain the lower 8 bits of the 512 
table entries, and LUTO and LUT2 contain the higher 8 bits of the 512 table entries. 
In this configuration, bit segments 6203 and 6204 are not used; and 6213 and 6214 
are set to zero. 

[00257] Figure 43 shows a configuration where 2 10-bit indices are used in 16 
look-up units to simultaneously look up 2 16-bit data using a single instruction. For 
example, an index is stored in B0 and Bl (6301 and 6302). Bl contains the lower 8- 
bits of the index; and BO contains the remaining two bits. Bl is used to look up data 
in look-up units 6331 - 6338 (LUTO - LUT7). Multiplexer 6321 selects a result from 
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the output of LUTO - LUT7 into DO and Dl (6311 and 6312), depending the index 
bits in BO. Dl contains the lower 8 bits of the result; and DO contains the higher 8 
bits of the result. When BO is 0, the index is in the range of 0 to 255, and the results 
from LUTO and LUT1 are selected; when BO is 1, the index is in the range of 256 - 
51 1, and the results from LUT2 and LUT3 are selected; when BO is 2, the index is in 
the range of 512 - 767, and the results from LUT4 and LUT5 are selected; when BO 
is 3, the index is in the range of 768 - 1023, and the results from LUT6 and LUT7 
are selected. LUT1, LUT3, LUT5 and LUT7 contain the lower 8 bits of the 1024 
table entries, and LUTO, LUT2, LUT4 and LUT6 contain the higher 8 bits of the 
1024 table entries. In this configuration, bit segments 6303 - 6308 are not used; and 
6313 - 6318 are set to zero. 

[00258] Figure 44 shows a flow diagram for a method to perform table look-up 
of a vector of data elements according to one embodiment of the present invention. 
In operation 6401, the instruction is decoded (e.g., by instruction dispatcher 2819, or 
by instruction decoder 1502). A configuration indicator is generated in operation 
6403. The configuration indicator indicates how to configure the look-up units into a 
number of look-up tables for the execution of the instruction. According to the 
configuration indicator, operation 6405 configures the look-up units into look-up 
tables. In operation 6407, a vector of numbers are received as indices for the vector 
look-up operation using the look-up tables. Operation 6409 simultaneously looks up 
a vector of data elements, each data element from one of the look-up tables using a 
corresponding index. Since the look-up tables are configured from the plurality of 
look-up units according to the configuration indicator, indices are typically generated 
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from the plurality of numbers for look-up operations in the look-up units, and the 
results from the look up units are selected and combined into the plurality of data 
elements. For some configuration, only a subset of the plurality of look-up units is 
used to form the look-up tables. Operation 641 1 outputs the vector of looked-up data 
into a register file (or memory). 

[00259] Figure 45 illustrates a block diagram representation of a circuit for the 
execution of a method to load entries in look-up units using DMA controllers 
according to one embodiment of the present invention. Configuration 6510, 
specified by an instruction, selects a DMA controller from a number of DMA 
controllers to load table entries from a location in memory 6503 into look-up units 
6501. These look-up units can be configured into look-up tables of different sizes, as 
illustrated in Figures 38, 39, 41 - 43 so that simultaneous look-up of a vector of data 
elements can be performed. In one embodiment of the present invention, one of the 
DMA controllers 6520 is DMA controller 2818 in a compute engine in Figure 18, 
and memory 6503 is host memory 1412 in Figure 4B. 

[00260] Figure 46 illustrates data representations for the execution of a method to 
load entries in look-up units using DMA controllers according to one embodiment of 
the present invention. Instruction 6610 illustrates the data representation in 
instruction dlutl. Bit segment 6602 specifies the DMA controller to be used in 
loading the entries. Bit segments 6601 and 6605 specify the identification of the 
instruction. Bit segments 6603 and 6604 contain two indices of entries A and B in 
register file 6620 (e.g., general purpose register file 2801 in Figure 18). Entry B 
contains Effective Address (EA) 6623 indicating the base address of the data in 
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memory 6503. Entry A contains bit segment 6621 which specifies a count indicating 
the number of entries to be loaded in each of the look-up units. Segment 6622 
specifies an index, which indicates the position of the first entry to be loaded in the 
look up units. Thus, the count and the index determine the location of the entries to 
be loaded in the look-up units. For example, the index (6622) indicates that entries 
start from entry 6651 (SO) in look-up unit 6631 (LUTO) will be loaded using the 
instruction. The count (6621) determines that the last entry to be load in LUTO is 
entry 6641 (E0). The same index and count also specifies that the entries between 
entry 6659 (S15) and entry 6649 (E15) will be loaded for look-up unit 6639 
(LUT15). 

[00261] Although Figure 46 illustrates an example instruction of loading 16 look- 
up units using a DMA controller, it will be appreciated that other instructions may be 
implemented to load the look-up units in different fashions, such as loading a 
number of entries in a selected number of look-up units only. 
[00262] Figure 47 shows a flow diagram for a method to load entries in look-up 
units using DMA controllers according to one embodiment of the present invention. 
After an instruction is decoded in operation 6701, an address indicating the location 
of the entries in memory 6503 is retrieved from a register file in operation 6703. A 
number of control parameters, such as count 6621 and index 6622, are also retrieved 
from the register file. In operation 6705, a DMA controller specified by the 
instruction loads the entries from memory 6503 into look-up units 6501. 
[00263] Figure 48 illustrates a block diagram representation of a circuit for the 
execution of a method to set entries in look-up tables according to one embodiment 
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of the present invention. The vectors of 8-bit numbers, vS and vB, are stored in two 
entries (6801 and 6802) of a vector register file (e.g., vector register file 2802 in 
Figure 18). After the execution unit receives control information from the 
instruction dispatcher, 8-bit indices 6831 (SO), 6832 (SI), and 6839 (Sn) are 
selected from entry 6801 for vS. 8-bit data items 6841 (BO), 6842 (Bl), 6849 
(Bn) are selected from entry vB (6802). The entries in look-up tables 6811 - 6819, 
pointed to by indices SO - Sn, are simultaneously replaced by the corresponding data 
items (B0 - Bn). For example, an entry indexed by SO in LUT0 is replaced by data 
item B0; and an entry indexed by Sn in LUTn is replaced by data item Bn. 
[00264] Figure 49 illustrates data representations for the execution of a method to 
set entries in look-up tables according to one embodiment of the present invention. 
Instruction 6910 illustrates the data representation in instruction vlutw8a. In vector 
register file 6920, bit segments 6902 and 6903 contain the addresses of two entries, 
vS and vB. Entry vS contains 16 8-bit indices; and entry vB contains 16 8-bit entries. 
For example, bit segment 6921 contains index SO; and bit segment 6951 contains 
data item B0. After the execution of the instruction, the data items in entry vB 
replace the corresponding entries of the look-up units indexed by the indices in vS. 
For example, entry 6941 in look-up unit 6931 (LUT0), indexed by SO, is replaced by 
B0; similarly, entry 6949 in look-up unit 6939 (LUT16), indexed by S15, is replaced 
byB15. 

[00265] Figure 50 shows a flow diagram for a method to set entries in look-up 
tables according to one embodiment of the present invention. In operation 7001, the 
execution unit receives a vector of indices and a vector of data items. Operation 
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7003 simultaneously replaces one entry in each of a number of look-up tables with a 
corresponding data item in the vector of data items. Each of the entry being replaced 
is being pointed to by a corresponding index in the vector of indices. 
[00266] A least one embodiment of the present invention seeks to perform a 
generic operation for variable length decoding by using a single instruction in an 
execution unit. The execution unit simultaneously performs all the table look-up 
operations for variable length decoding a code word in the single instruction. The 
execution unit has look-up memory which can be configured into a number of look- 
up tables in a fashion indicated by the instruction in order to simultaneously look up 
a vector of data elements, each from one of the look-up tables. In one embodiment of 
the present invention, the look-up memory comprises a number of look-up units. The 
execution unit further processes the data items selected from the look-up tables to 
provide a decoded value. By parallel processing the look-up operations, a method 
according to the present invention dramatically increases the performance for 
variable length decoding. 

[00267] Figure 51 illustrates a block diagram representation of a circuit for the 
execution of a method to perform variable length decoding according to one 
embodiment of the present invention. A bit stream is stored in entry 7101 in a vector 
register file. The bit stream contains a number of code words to be decoded. Bit 
pointer 7152, table offset 7151, escape format 7153, and fence bits 7154 are stored 
in other entries of the vector register file. After the execution unit receives control 
information for the instruction dispatcher, bit selectors 7103 select a number of bit 
segments from bit stream 7101 to generate indices 7121, 7122, 7129 for look-up 
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tables 7109 using local control information 7111, 7112, 7119. Bit pointer 7152 
indicates the position of the starting bit of the current code word in the bit stream. 
Local control information 7111, 7112, 7119 are stored in an entry of the vector 
register file. Each of the local control information indicates a location and a length of 
the bit segment to be selected from the bit stream to construct the index. Table offset 
7151 is combined with the bit segments selected by bit selectors 7103 to generate the 
indices. The details of one embodiment of the bit selector are illustrated in Figure 
54, and will be described in the following paragraphs. 

[00268] A number of look-up units 7109 are configured into a number of look-up 
tables according to the configuration signal from the instruction. Code selector 7105 
combines data entries 7131, 7132, 7139, looked up from the look-up tables 
(7109), and sign bits 7141, 7142, 7149, selected by bit selectors 7103, to 
produces an intermediate result, which includes: i) halfword data DT0 (7163) and 
DTI (7164); ii) data type 7162 (Type); and iii) the number of bits of the current code 
word (NumBits 7161) (if a valid data entry is found in the look-up tables). At the 
same time, escape formator 7106 formats a segment of bits into halfword escape 
data El (7168) and E0 (7169) according to escape format 7153, assuming that the 
current code word is for escape data. Finally, finalizor 7107 combines fence bits 
7154 with intermediate results 7161 - 7164, and escape data 7168 and 7169 into: i) 
new bit pointer 7181 (NPtr), which is the position of the starting bit of the next code 
word in the bit stream; ii) adjust bit stream indicator 7182 (ADBS), which indicates 
whether there are in fact enough bits in the bit stream for the current code word; iii) 
entry not found indicator 7183 (ENF), which is set when there is no valid entry 
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found in the look-up tables, iv) end of block indicator 7184 (EOB), which indicates 
whether the end of block condition is met, and v) resulting decoded data 7185 and 
7186 (RO and Rl). The details of one embodiment of the code selector 7105 are 
illustrated in Figure 55; escape formator 7106 illustrated in Figure 57; and finalizor 
7107 illustrated in Figure 59. 

[00269] Although Figure 51 illustrates only one escape formator, it will be 
appreciated that a number of escape data can be formatted according to a number of 
escape formats by using a number of escape formator in parallel (or by using an 
escape formator to sequentially format the escaped data according to the escape 
formats). 

[00270] Figures 52 - 53 illustrate block diagram representations of circuits for 
performing variable length decoding using a set of look up units according to one 
embodiment of the present invention. 

[00271] Figure 52 illustrates one configuration in which 16 look-up units are 
configured into 8 look-up tables 7251 - 7258. Each of the tables contains 256 16-bit 
entries. For example, an 8-bit index is stored in B0 (7201). Look-up unit 7231 
(LUT0) contains the lower 8 bits of the entries; and LUT1 (7232) contains the upper 
8 bits of the entries. The 8-bit index in B0 is used to simultaneously look up the 
lower and upper 8 bits of the entry. The lower 8 bits of the result are stored in DO 
(721 1); and the upper 8 bits of the result are stored in Dl (7212). 
[00272] Figure 53 illustrates one configuration in which 16 look-up units are 
configured into 5 look-up tables 7351 - 7355. Each of the tables contains 256 24-bit 
entries. For example, an 8-bit index is stored in Bl (7302). Look-up unit 7331 
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(LUTO) contains bits 0-7 of the entries; LUT1 (7332) contains bits 8-15 of the 
entries; and LUT2 (7333) contains bits 16-23 of the entries. The 8-bit index in BO is 
used to simultaneously look up bits 0-7, 8-15, 16-23 of the entry. Bits 0-7 of the 
result are stored in DO (731 1); bits 8-15 of the result are stored in Dl (7312); and 
bits 16-23 of the result are stored in D2 (7313). In this configuration, LUT15 (7339) 
is not used. 

[00273] Figure 54 illustrates a detailed block diagram representation of a circuit 
to select a segment of bits from a bit stream according to one embodiment of the 
present invention. Local control information 7304 (LI) contains: i) IgnBits 7311, 
which indicates the number of bits to be ignored starting from the bit pointed to by 
bit pointer 7303 (Ptr), and ii) IdxBits 7312, which indicates the number of bits to be 
taken from bit stream 7301. Entry 7301 in a vector register file contains 128 bits of 
the bitstream of code words to be decoded. Ptr 7303 points to the first bit of the 
current code word to be decoded in bit stream 7301. The shifters 7335 and 7337 
select from the bit stream a bit segments of a length specified by IdxBits 7312, 
starting from the bit pointed to by Ptr+IgnBits. The selected bit segment is combined 
with table offset 7302 using operation 7339 to produce index Al (7341). Similarly, 
shifters 7331 and 7333 are used to obtain the sign bit, which immediately follows the 
bit segments specified by local control information 7304 (IgnBits 731 1 and IdxBits 
7312). The sign bit is selected into SI (7349). While Figure 54 illustrates one 
embodiment of a bit selector 7340, it will be apparent to one skilled in the art that 
many variations of the bit selector may be implemented to carry out the same 
function as in Figure 54. 
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[00274] Figure 55 illustrates a detailed block diagram representation of a circuit 
to select a valid data from the look-up results of a number of look-up tables 
according to one embodiment of the present invention. Code selector 7590 selects 
and formats a valid data using data entries 7501, 7503, 7505, 7507 and their 
associated sign bits 7502, 7504, 7506, 7508. A typical data entry Dx from a 3-byte 
look-up table contains: i) control data Ctrl (7561); ii) halfword data DxO (7562) and 
Dxl (7563). Control data Ctrl contains: i) NumBits (7581), which indicates the 
number of bits for a code word corresponding to data entry Dx; and ii) Type 7582, 
which indicates the type of data entry Dx. Logic unit 751 1 determines from the 
control data of DO (7501) if the data (DO) is valid. When the data is of a valid type, 
logic unit 7531 outputs zero to suppress the results of other look-up tables from 
entering into Dx and Sx (7565 and 7566). At the same time, logic unit 7541 
produces a signal causing gate 7551 to output data entry DO (7501) and its associated 
sign bit SO (7502) into Dx and Sx. When the data (DO) is not valid, logic unit 7541 
generates a signal causing gate 7551 to prevent DO and SO from entering into Dx and 
Sx. At the same time, logic unit 7513 output a signal to enable the selection of result 
from Dl and SI. Thus, when DO is not valid, logic units 7513, 7523, 7533, 7543 and 
7553 selects Dl and S 1 into Dx and Sx if Dl is valid. When both DO and Dl are not 
valid, D2 and D3 may be selected in a similar fashion. Thus, the result in DO has the 
highest priority, and the result in D3 has the lowest priority. A valid result with the 
highest priority is selected into Dx. In one embodiment of the present invention, 
when no entry is valid, the last entry is selected into Dx and Sx. Code Formator 7570 
extracts NumBits 7581, Type 7582, DT0 and DTI from the selected code Dx with 
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its associated sign bit 7566. Details of code formator 7570 are illustrated in Figure 
56. 

[00275] Figure 56 illustrates a detailed block diagram representation of a circuit 
to format a valid data from a look-up table according to one embodiment of the 
present invention. According to configure 7610, multiplexer 7613 selects a halfword 
from data entries 7602 and 7604 to perform formatting. When the configuration 
determines that the entry is a 2-byte data item, DxO is selected; when the 
configuration determines that the entry is a 3-byte data item, Dxl is selected. Logic 
unit 7615 formats the selected data assuming the data is of type sign magnitude. 
Logic unit 7617 formats the selected data assuming the data is of type two 
complement. Ctrl 7601 contains NumBits 7631 and Type 761 1. The type of data 
entry 761 1 causes multiplexer 7619 to select a correctly formatted data. When the 
configuration is for 2-byte data entry, multiplexer 7621 selects the formatted data 
into DT0 (7633); when the configuration is for 3-byte data entry, multiplexer 7621 
selects DxO (7602) into DT0 (7633). Thus, code formator 7630 formats DxO and 
Dxl into DT0 and DTI according to the type of the data specified in control data 
7601. 

[00276] Figure 57 illustrates a detailed block diagram representation of a circuit 
to format an escape data from a bit stream according to one embodiment of the 
present invention. Escape data format 7702 (Esc) contains: i) EscType 7711, which 
specifies the type of the escape data; ii) EscDOBits 7712 and EscDIBits 7714, which 
specify the numbers of bits in bit stream 7701 for the first and second half words of 
data; and iii) EscCdBits 7713, which specifies the number of bits of the escape 
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symbol. Logic units 7721 and 7731 perform modulo 16 operations. Shifters 7723 
and 7724 select the first halfword DataO (7751) from bit stream 7701; shifters 7733 
and 7734 select the second halfword Datal (7753) from the bit steam; and shifters 
7745 and 7746 select the sign bit Sgn (7752) of the escape data. Multiplexer 7747 
selects FrmtBits 7754 from EscDOBits and EscDIBits. When the configuration is for 
2-byte data entry, multiplexer 7747 selects EscDOBits as FrmtBits, since DataO will 
be formatted by Esc Code Formator 7765 in this configuration; when the 
configuration is for 3-byte data entry, multiplexer 7747 selects EscDIBits as 
FrmtBits, since Datal will be formatted by Esc Code Formator 7765 in this 
configuration. Esc code formator 7765 formats DataO and Datal into El and E0 
(7761, 7762) according to EscType 7711, Sgn 7752, and FrmtBits 7754. Figure 58 
illustrates the detail of Esc code formator 7765. 

[00277] Figure 58 illustrates a detailed block diagram representation of a circuit 
to format an escape data obtained from a bit stream according to one embodiment of 
the present invention. Multiplexer 7811 selects data from DataO (7803) and Datal 
(7804) to perform formatting. When the configuration is for 2-byte data entry, 
multiplexer 781 1 selects DataO; when the configuration is for 3-byte data entry, 
multiplexer 7811 selects Datal. Logic unit 7813 formats the selected data assuming 
the data is of type sign magnitude. Logic unit 7815 formats the selected data 
assuming the data is of type two complement. EscType 7801 causes multiplexer 
7619 to select a correctly formatted data. When the configuration is for 2-byte data 
entry, multiplexer 7819 selects the formatted data into E0 (7831); when the 
configuration is for 3-byte data entry, multiplexer 7819 selects DataO (7803) into E0. 
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Thus, Esc code formator 7820 formats DataO and Datal into E0 and El according to 
the type information 7801. 

[00278] Figure 59 illustrates a detailed block diagram representation of a circuit 
to generate the result of variable length decoding using the escape data and the data 
from look-up tables according to one embodiment of the present invention. Type 
7904 obtained from code formator 7630 of code selector 7590 (or 7105) decides 
whether the current code word is for an escape data item. If it is for an escape data 
item, multiplexer 7917 selects the formatted escape data E0 and El (7906, 7907) as 
result R0 and Rl (7941, 7942); otherwise, formatted data DT0 and DTI (7908, 
7909) obtained from look-up tables are selected into R0 and Rl. At the same time, 
logic unit 7921 sets end of block indicator 7933 (EOB) by determining if Type 7904 
is for a code word representing the end of block condition; logic unit 7923 sets entry 
not found indicator 7934 (ENF) by checking if Type 7904 is for a valid code word. 
Meanwhile, adder 7911 sums up NumBits 7902 and Ptr 7903 into NPtr (7932), 
which points to the starting bit of the next code word. Adder 7914 sums NPtr and 
fence bits (7901) in order to determine if the result of the look-up is in fact based on 
valid bits in the bit stream. When the sum is smaller than 128, tester 7915 unsets 
ADBS (7931) indicating that there are enough valid bits in the bit stream to decode 
the current code word, and the decoded result is valid; otherwise, ADBS is set to 
indicate that there are not enough valid bits in the bit stream to decode the current 
code word, and the bit stream must be adjusted. 

[00279] Figure 60 illustrates data representations for the execution of a method to 
perform variable length decoding according to one embodiment of the present 
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invention. Instruction 8010 illustrates the data representation in instruction vvld for 
the variable length decoding of a code word in a bit stream. Bit segments 8001 and 
8006 contain the identification of the instruction. Bit segments 8002, 8003, 8004, 
and 8005 contain the addresses of four entries in a vector register file 801 1. Segment 
8003 contains an address for entry vA, which contains bit stream 8009. Bit segment 
8071 represents the bits for a code word to be decoded. Typically, a sign bit 8072 
follows immediately the bits for a code word (8071), although some code words 
have no associated sign bit. Bit 8073 represents the last valid bit for code words in 
the bit stream. The bit pointer (Ptr) points to the position of the first bit of code 8071 
and is stored in segment 8047 in entry vB. The address of entry vB is specified in 
segment 8004 in instruction vvld (8010). The number of bits between bit 8073 and 
the last bit in entry vA is FenceBits, which is stored in bit segment 8022 of entry vC. 
The address of entry vC is specified in segment 8005 in instruction vvld. FenceBits 
is stored in segment 8020 in vC for global control signal. In addition to FenceBits, 
Global control signal 8014 contains: i) TableOffset 8021, which is used in 
generating indices for table look-up operations; ii) Config 8023, which indicates 
whether entries in look-up tables are 2-byte data or 3-byte data; and iii) EscO 8025 
and Escl 8026, which specify two formats of escape data. Each of the escape 
formats (EscO or Escl) has the data representation 8016 and contains: i) EscType 
8061 indicating the type of the escape data (e.g., two complement, zero fill, or sign 
magnitude); ii) EscCdBits 8062 indicating the number of bits used for the escape 
symbol; and iii) EscDOBits 8063 andEscDIBits 8064 which are the numbers of bits 
for the first and second halfword escape data. Segment 8017 represents a typical 
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escape data element in a bit stream. Escape symbol 8075 is a code word indicating 
that an escape data (8076 and 8077) follows immediately after the symbol. EscDO 
and EscDl (8076, 8077) are the bit segments representing the first and second 
halfword data of the escape data. Sign bit 8078 follows immediately after the bit 
segments (8076, 8077). 

[00280] The bit segment (8030) for local control signal 8013 contains information 
for 8 bit segments, L0, LI, L7 (8031 - 8038). Each local control information Lx 
(8015) contains: i) IgnBits (8054) indicating the number of bits to be ignored after 
the bit pointed to by Ptr (8047); and ii) IdxBits (8055) indicating the number of bits 
of the bit segment to be used in the construction of the index for one of the look-up 
tables. 

[00281] Segment 8002 in instruction vvld (8010) specifies the address of entry vD 
in the vector register file (8011). After the execution of the instruction, the first and 
second halfword decoded values are stored in R0 and Rl (8041, 8042) in vD. NPtr 
(8044) stores the bit pointer pointing to the first bit of the next code word to be 
decoded. RawResult (8043) stores the decoded values before being formatted 
according to the data type (e.g., two complement, sign magnitude). 
[00282] Condition register 8012 stores the indicators for various conditions 
encountered during the decoding, including: i) EOB, indicating whether the current 
code word represents the end of block condition; ii) ADBS, indicating whether it is 
necessary to adjust bit stream in order to decode the current code word; and iii) ENF 
(Entry No Found), indicating if no valid entry is found in the look-up tables for the 
specified local controls. 
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[00283] A typical entry from a look-up table has data representation 8018. 
Corresponding to Ctrl 7561 in Figure 55, the first byte of the entry contains: i) Type 
8056 indicating the type of the entry (e.g., invalid codeword, valid codeword, EOB, 
escape data, etc.), and ii) NumBits 8057 indicating the total number of bits used by 
the current code word. The second and the third bytes (8058 and 8059) contain the 
decoded data. In one configuration, the look-up tables contain only 16-bit entries. In 
this case the third byte is not relevant. 

[00284] While Figure 60 illustrates one embodiment of the data representation 
for the execution of an instruction to perform variable length decoding, it will be 
apparent to one skilled in the art that many variations of the data representation may 
be used for the instruction described above. 

[00285] Figure 61 shows a flow diagram for a method to perform variable length 
decoding according to one embodiment of the present invention. Operation 8121 
fetches a plurality of bit segments from a bit stream according to a plurality of 
escape data formats (obtained from input vector registers). Operation 8123 generates 
a plurality of escape data from the bit segments obtained in operation 8121 
according to the escape data formats. In parallel to operations 8121 and 8123, 
operation 8101 fetches bit segments from the bit stream according to a plurality of 
local control data. The bit segments obtained in operation 8101 are used to construct 
indices which are simultaneously used to look up data entries from a plurality of 
tables. Operation 8131 combines the data entries looked up from tables with the 
escape data into a resulting data. Operation 8133 outputs: i) the decoded value; ii) a 
new pointer pointing to the starting bit of the next code word; iii) an ENF indicator 
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indicating whether a valid entry is found in the look-up tables; iv) an EOB indicator 
indicating whether an end of block condition is found; and v) an ADBS indictor 
indicating whether the bit stream must be adjusted in order to correctly decode the 
current code word. In one embodiment of the present invention, the operations in 
Figure 61 are performed by an execution unit for the execution of a single 
instruction. 

[00286] Figure 62 shows look-up tables for variable length decoding code words 
encoded using DV standard according to one embodiment of the present invention. 
Four look-up tables are used (Tl, T2, T3, and T4). Each table entry contains 
information about type, bits, run and level, corresponding to Type 8056, NumBits 
8057, DxO 8058, and Dxl 8059 respectively. In one embodiment of the present 
invention, type 0 represents invalid entries; type 1 represents the end of block 
condition (EOB); type 2 represents EscO (Escape data); type 3 represents Escl 
(Escape data); type 4 represents two complement; and type 5 represents sign 
magnitude. 

[00287] To use the look-up tables in Figure 62, Config 8023 in global control 
8014 (in Figure 60) is set to 3 to configure the look-up units into 5 look-up tables, 
each having 256 3-byte entries. Figure 53 illustrates such a configuration. The 
tables in Figure 62 are loaded into the look-up units for the first four look-up tables, 
while the look-up units for the fifth look-up table are loaded with zeroes. 
[00288] Since look-up tables shown in Figure 62 use only the memory in the 
look-up tables associated with the lower 64 addresses (i.e., 0- 63), it will be 
appreciated that look-up tables for other operations can use the rest of the memory. 



04860.P2687 



105 



Thus, multiple sets of look-up tables, which may be for different purpose, may co- 
exist in the look-up units. This allows the use of multiple sets of look-up tables in a 
sequence of instructions, without having to load the tables multiple times. 
[00289] To use the look-up tables in Figure 62, the control information in vector 
vC (GlobalControl 8020 and LocalControl 8030 in Figure 30) are: 



Table Offset = 0; 

Fence Bits = 0; 
Conf ig = 3 ; 
EscO = { 

EscType = 3 ; 

EscCdBits = 7; 

EscDOBits = 5; 

EscDIBits = 15; 



// bits 0 - 7 in the vC 

// register 

// bits 9-15 

// bits 21 - 23 

// for {run, 0} pairs 

// bits 32 - 34 (Zero Fill) 

// bits 35 - 39 

// bits 40 - 43 

// bits 44 - 47 



Escl = { 

EscType = 1; 

EscCdBits = 7; 
EscDOBits = 15; 
EscDIBits = 7; 



// for {0, amp} pairs 

// bits 48 - 50 (Two 

// Complement) 

// bits 51 - 55 

// bits 56 - 59 

// bits 60 - 63 



L0 = { // Tl control data 

IgnBits =0; // bits 64 - 68 

IdxBits =5; // bits 69 - 71 

} 



LI = { 



} 

L2 
} 



IgnBits = 2; 
IdxBits = 5; 



= { 
IgnBits = 4; 
IdxBits = 5; 



// T2 control data 
// bits 72 - 76 
// bits 77 - 79 



// T3 control data 
// bits 80 - 84 
// bits 85 - 87 
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.53*: 



L3 = { // T4 control data 

IgnBits = 6; // bits 88 - 92 

IdxBits = 5; // bits 93 - 95 



L4 = { // zero 

IgnBits =0; // bits 96 - 100 

IdxBits = 0; // bits 101 - 103 



L5 = { // not used 

IgnBits = 0; // bits 104 - 108 

IdxBits = 0; // bits 109 - 111 



L6 = { // not used 

IgnBits = 0; // bits 112 - 116 

IdxBits = 0; // bits 117 - 119 



L7 = { // not used 

IgnBits =0; // bits 120 - 124 

IdxBits =0; // bits 125 - 127 



[00290] After packing, GlobalControl (8013 in Figure 60) is 

0x00000300675f47f7; 

[00291] and LocalControl (8014 in Figure 60) is 

0x0515253500000000. 

[00292] Thus, the control information in vector vC (8020 and 8030 in Figure 30) 

is 

vC = 0x00000300675f47f70515253500000000. 
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[00293] The control information typically remains the same in a decoding loop. 
[00294] The following sequence of instructions decode a bit stream loaded in a 
vector register until all tokens are decoded (e.g., EOB or End Of Block), or end of 
bit stream (e.g., ADBS or ADjust Bit Stream) is reached, or error in decoding (e.g., 
ENF or Entry Not Found) is detected. While a Vector Look Up Table Unit (e.g., 
VLUT 281 1 in Figure 18) is decoding a code word, other processing units (e.g., 
LSU 2816, BRU 2824, IALU 2805 in Figure 18) are used to look up inverse zigzag 
table and inverse scale table to compute an IDCT coefficient using the decoded 
values from a previous code word. 



// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 
// 



Vector vld loop example 
Vector register usage: 

vA - right justified bitstream (0 fence bits - always) 

vB - current and next bit pointers 

vC - wld control information (initialized) 



Scalar 
rScratch 
rZztab 
rlstab 
rIDCT 
rRun 
rLevel 
rTzzt 
rTist 
rPtr 
rTmp 



register usage: 

- pointer to 

- pointer to 

- pointer to 

- pointer to 

- currently 



a scratch area 

the inverse zigzag look-up table 
inverse scale table 
storage area for IDCT coefficients 
decoded run 



currently decoded level 

temporary 

temporary 

coefficient pointer 

for updating coefficient pointer 



{ wld(vB, vA, vB, vC) ; 
} // group B0 



label^LOOP: 



// VLUT: variable length 
// decoding 
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{ stv(vB, rScratch, 0) ; 

wld(vB, vA, vB, vC) ; 
} // group Bl 

{ sadd(rTzzt, rZztab, rPtr) ; 

lhz(rRun, rScratch, 0) ; 
} // group B2 



// LSU: store decoded result 

// in the scratch area 

// VLUT: decode next code 

/ / word 



// IALU: compute offset into 
// inverse zigzag table 
// LSU: load decoded run 



sadd(rTist, rlstab, rPtr) ; 

lhz (r Level , rScratch, 2 ) ; 
bceob (label_EOB) ; 

// group B3 



// IALU: compute offset into 

// inverse scale table 

// LSU: load decoded level 

// BRU: conditional branch 

// on EOB 



sadd(rTmp, rPtr, rRun) ; 
lbzx(rTist, rRun 7 rTist) ; 
bcnoentry ( label_ENF ) ; 

// group B4 



// IALU: prepare rPtr update 

// LSU: load inverse scale 

// BRU: conditional branch 

// on ENF 



sslw(rLevel, rLevel, rTis 

lbzx(rTzzt, rRun, rTzzt) ; 
bcadbs (label_ADBS) ; 

// group B5 



); // IALU: inverse scale 

// coefficient 

// LSU: load zigzag index 
// BRU: conditional branch 

// on ADBS 



{ saddi(rPtr, rTmp, 1) ; 

sthx(rLevel, rIDCT, rTzzt); 

bc(label_LOOP) ; 
} // group B6 

// process End Of Block (EOB) 
label_E0B: 



// IALU: update rPtr 

// LSU: store resulting 

// IDCT coefficient 

// BRU: unconditional branch 



// process ADjust Bit Stream (ADBS) 
label__ADBS: 



// process Entry Not Found (ENF) 
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label_ENF: 
• • • 

[00295] When the instructions in group BO are executed, VLUT performs a 
variable length decoding operation by executing the vvld instruction. Before the 
execution of the vvld instruction, look-up tables (e.g., Tl - T4 in Figure 62) are 
loaded into look-up units; a bit stream is loaded into vector register vA; control 
information for vvld is loaded in vector register vC; and a bit pointer, pointing to the 
first bit of the first code word in vA, is stored in vector register vB. The bit stream in 
vA is right justified so that the input for fence bits is always 0. After the execution of 
the vvld instruction, the decoded run and level are stored in the vector register vB. 
The bit pointer in vB is updated to point to the next code word. 
[00296] The decode loop starts with instruction group Bl. In group Bl, LSU 
stores the decoded run and level in a temporary area defined by the address in 
register rScratch. At the same time, VLUT starts to decode the next code word in 
vA. 

[00297] While VLUT decoding the next code word in vA, other processing units 
receives instructions in group B2 - B6 to process the decoded run and level, stored at 
the scratch area, to compute an IDCT coefficient. 

[00298] In group B2, IALU computes offset rTzzt to the inverse zigzag look-up 
table by adding pointer rZztab to coefficient pointer rPtr. Pointer rZztab points to the 
inverse zigzag look-up table; and rPtr represents an index to the current entry in the 
look-up table. At the same time, LSU loads the decoded run (rRun) from the scratch 
area. 
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[00299] In group B3, IALU computes offset rTzzt to the inverse scale look-up 
table by adding pointer rlstab (pointer to the inverse scale look-up table) to 
coefficient pointer rPtr. LSU loads the decoded level (rLevel) from the scratch area. 
At same time, BRU checks if EOB is detected during decoding the code word. If 
EOB is detected, BRU branches into labelJEOB. 

[00300] In group B4, IALU increases rPtr by rRun and stores the result in rTmp. 
LSU loads the inverse scale from the look-up table pointed by rTist with an offset 
rRun and saves the result in rTist. BRU conditionally branches on condition ENR 
[00301] In group B5, IALU left shifts the decoded level (rLevel) to generate an 
IDCT coefficient and stores the result in rLevel. LSU loads the zigzag index into 
register rTzzt. BRU conditionally branches on condition ADBS. 
[00302] In group B6, IALU updates coefficient pointer rPtr. LSU stores the IDCT 
coefficient in the buffer area rIDCT using the pointer rTzzt looked up from the 
inverse zigzag table. 

[00303] In one embodiment of the present invention, a vector register contains 
128 bits and can always accommodate one compressed DV block. When BRU 
conditionally branches on condition EOB or ADBS, the un-decoded data in the 
vector register file is stored for later use. In the above code sequence, a code word is 
decoded in 6 cycles. In parallel with variable length decoding operations, IDCT 
coefficients are computed and stored in an array suitable for the Inverse Discrete 
Cosine Transformation. Thus, a method for variable length decoding compressed 
video images according to present invention is very efficient. Note that different 
implementations may have different latencies and dispatch rates for various 
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instructions. Once the latencies and dispatch rates are determined, the methods of 
the present invention can be implemented accordingly using different code 
sequences. 

[00304] At least one embodiment of the present invention seeks to utilize random 
access capability of a vector look up unit (e.g., updating and looking up entries in 
look up tables in a vector look up unit using a set of indices) to transpose a matrix 
efficiently. It will be understood that the elements of a matrix do not have to 
represent numbers. 

[00305] Figure 75 shows methods to transpose a matrix using operations that 
change the positions of elements within rows or within columns. In Figure 75, 
operations 9511, 9513 and 9515 transpose matrix 9531 into matrix 9534. Operation 
9511 repositions elements within rows to generate matrix 9532. For example, row 
9501 (vector va6) may be rotated in a vector register to generate row 9503 (vector 
vb6). Operation 9513 repositions elements within rows to generate matrix 9533. For 
example, elements in column 9502 may be rearranged to generate column 9504 
(column c5). In one embodiment of the present invention, operation 9513 is 
performed by writing matrix 9532 one row at a time into a vector of look up unit 
using one set of indices and looking up matrix 9533 one row at a time from the 
vector look up unit using another set of indices. More details are described below. 
[00306] Operation 9515 repositions elements within rows to generate matrix 
9534. For example, row 9505 (vector vc5) is rotated in a vector register to generate 
row 9507 (vector vc5). 
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[00307] In one embodiment of the present invention, each vector register can hold 
128 bits (i.e., the vector width is 128 bits). Thus, a vector register can hold 8 16-bit 
elements. For example, vector 9501 can be stored and rotated in a vector register to 
generate vector 9503. A vector look up units can hold 16 look up tables, each of 
which contains 256 8-bit data items. An 8-bit bit segment of a matrix element can be 
stored and looked up from one look up table, and the other 8-bit bit segment of the 
matrix element can be stored and looked up from another look up table. Figure 76 
shows examples of indices that may be used in a plurality of look-up tables to 
change the positions of elements within columns. Indices 9633 may be used to write 
rows of matrix 9532 into the 16 look up tables; and indices 9631 may be used to 
look up rows of matrix 9533 from the 16 look up tables. For example, indices 9607 
may be used to write row 9503 into the look up tables. The element (a67) of row 
9503 and column 9502 are written into look up table T10 and Tl 1 . The lower 8 bits 
of a67 are written into table T10; and the upper 8 bits of a67 is written into table 
Tl 1. Similarly, indices 9601 may be used to look up row 9505 from the look up 
tables. Thus, after using indices 9613 to write the elements into tables T10 and Til 
and using indices 961 1 to look up elements from tables T10 and Tl 1, the positions 
of the elements of column 9502 is changed to those in column 9504. 
[00308] In a reverse order, operations 9515, 9513 and 951 1 transpose matrix 9534 
into matrix 9531. Thus, indices 9631 can be used to write the rows of matrix 9533 
into the vector look up unit, and indices 9633 can be used to look up the rows of 
matrix 9532 from the vector look up unit. 
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[00309] Notice that a row of indices 9633 may be computed by adding a row of 
constants to another row indices. For example, row 9607 can be computed by adding 
a row of ones to row 9605. Similarly, a row of indices 9631 may be computed by 
rotating another row of indices. For example, row 9603 can be obtained by rotating 
row 9601. Thus, the indices 9631 and 9633 may be generated using simple vector 
operations from two vectors of indices. 

[00310] Figure 76 illustrates examples of indices which may be used to 
repositioning the elements within columns. Using the indices shown in Figure 76, a 
matrix (e.g., matrix 9532) is written into a rectangular area in the vector look up 
unit. However, other indices may also be used to repositioning the elements without 
having to store the matrix in a rectangular area in the vector look up unit. In general, 
any set of indices that do not map two different elements into a same location in the 
vector look up unit can be used to store the rows of a matrix into the vector look up 
unit; and a corresponding set of indices can be used to look up the rows such that the 
elements in the columns are positioned at desirable locations. Since the elements of 
each column are written in a look up table, a set of indices can be constructed to look 
up rows of elements such that the elements in the columns are in any given orders. 
[00311] While rotating in a vector register is a preferred way to repositioning the 
elements within rows, other vector operations may also be used to repositioning the 
elements, such as vector permutation operations. 

[00312] Although Figures 75 and 76 illustrate examples where each element of 
the matrix is a 16-bit data item (e.g., integer or floating point number), the methods 
illustrated in Figures 75 and 76 can also be used to transpose matrices of elements of 
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other data sizes, such as 8-bit or 32-bit. In a 128-bit vector processor, a 16x16 8-bit 
matrix can be transposed where an 8-bit element is written into and looked up from 
an 8-bit look-up table; and a 4x4 32-bit matrix can be transposed where a 32-bit 
element is split into 4 8-bit segments, each of which is written into and looked up 
from an 8-bit look-up table. The indices used for writing or looking up matrix 
elements depend on the data size of the elements of the matrix. For example, four 
indices are used in four 8-bit look up tables for 4 8-bit segments of a 32-bit element; 
2 indices are used in two 8-bit look up tables for 2 8-bit segments of a 16-bit 
element; and one index is used for an 8-bit element. 

[00313] Figure 77 shows a method to transpose a matrix using a vector processor 
according to one embodiment of the present invention. Operation 9701 loads each 
row of a matrix from memory (e.g., local memory 2817 in Figure 18 or host 
memory 1512 in Figure 5B) into a vector register (e.g., an entry in vector register 
file 2802). Operation 9703 repositions the elements within each row by rotating each 
row of the matrix in the vector registers (optionally, except one row of the matrix). 
In some embodiments, it is not necessary to reposition the elements in one of the 
rows of the matrix (e.g., row 9541). Operation 9705 writes each row into the vector 
look up unit using a set of indices generated according to the data size of the 
elements of the matrix. An instruction such as that illustrated in Figure 49 may be 
used to write the row into the vector look up unit. After all rows are written into look 
up tables, operation 9707 looks up rows from the look up units using another set of 
indices generated according to the data size of the elements of the matrix. An 
instruction such as that illustrated in Figure 41 may be used to look up the rows. 
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The rows looked up from the look up tables are rotated (optionally, except one of the 
rows) to obtain the rows of the transposed matrix. In some embodiments, it is not 
necessary to change the positions of the elements in one of the rows of the matrix 
(e.g., row 9543). 

[00314] It will be appreciated that it is not necessary to load or rotate all the rows 
before rotating the rows or writing the rows into look up units. A row can be first 
loaded, rotated and written into the vector look up unit before another row is 
processed. Operations 9701, 9703 and 9705 may be performed on different rows of 
the matrix in parallel using a number of execution units. Similarly, operations 9707, 
9709 and 971 1 may be performed on different rows in parallel. 
[00315] Figure 78 shows a flow chart for a method to transpose a matrix using a 
VLIW processor according to one embodiment of the present invention. A plurality 
of execution units (e.g., LSU 2816, VSIU 2809, VPU 2808, VLUT 281 1 shown in 
Figure 18) may be used to in parallel for matrix transposition. For example, while 
VLUT writes row n into look up units to update look up tables in operation 9807, 
VPU may rotate row n-1 in operation 9805; VSIU may computes indices for writing 
row n-1 in operation 9803 (e.g., by adding a vector of ones to the vector of indices 
for row n); and LSU may load row n-2 from memory in operation 9801. While 
VLUT looks up row n from look up tables in operation 9815 using pre-calculated (or 
pre-loaded) indices, VPU may rotate row n+1 looked up from VLUT in operation 
9813; and LSU may store row n-2 of the transposed matrix into memory in operation 
981 1. Alternative, the VSIU may calculate indices for looking up row n-1 (e.g., by 
adding a vector of ones to the vector of indices for row n) in parallel with operation 
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9815; in this case, operation 9803 is not performed and operation 9807 uses pre- 
calculated indices. 

[00316] One embodiment of the present invention is a code sequence to perform 
the transposition of an 8x8 16-bit matrix. In the following code sequence, various 
execution units execute the instructions in each group of instructions concurrently. 
Vector vone is a vector of ones. Vectors viO, vil, vi7 are the indices shown in 
Figure 76. Before the execution of instruction group CI, vectors vaO, val, va7 
contains the rows of the matrix (e.g., matrix 9531 in Figure 75); and vector vj is a 
vector of zeroes. After the execution of group CI 6, vectors vaO, val, va7 contains 
the rows of the transposed matrix (e.g., matrix 9534 in f75). In instruction group CI, 
a vector of ones is added by VSIU to vj to generate the index for writing val ; VPU 
rotates val left by 14 bytes; and VLUT updates the vector look up unit using the 
data entries in vector vaO indexed by indices in vector vj. In group CI, the vector 
that needs no rotation is written into the look up units first. In group CI 6, the last 
vector (vaO) that needs no rotation is looked up by VLUT, while VPU performs the 
last rotation operation on vector val. Thus, only 16 cycles are required to transpose 
an 8x8 matrix. 



{ vaddubs{vj, v j , vone); // VSIU computes index for val 

vsldoi(val / val, val, 14); // VPU rotates val left by 14 bytes 

vlutw8a(va0 / v j ) ; // VLUT writes vaO 

} // group CI 

{ vaddubs(vj, v j , vone); // VSIU computes index for va2 

vsldoi(va2, va2 , va2 , 12); // VPU rotates va2 left by 12 bytes 

vlutw8a(val, vj ) ; // VLUT writes val 

} // group C2 

{ vaddubs(vj, v j , vone); // VSIU computes index for va3 

vsldoi(va3, va3 , va3 , 10); // VPU rotates va3 left by 10 bytes 

vlutw8a(va2, vj); // VLUT writes va2 
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} // group C3 

{ vaddubs (vj , v j , vone) ; 

vsldoi (va4, va4, va4, 8); 

vlutw8a (va3 , vj ) ; 
} // group C4 

{ vaddubs (vj , vj , vone) ; 

vsldoi(va5, va5, va5, 6); 

vlutw8a {va4 , v j ) ; 
} // group C5 

{ vaddubs (vj, v j , vone); 

vsldoi (va6, va6, va6, 4) ; 

vlutw8a (va5 , v j ) ; 
} // group C6 

{ vaddubs (vj , vj , vone) ; 

vsldoi (va7, va7, va7, 2); 

vlutw8a ( va6 , vj ) ; 
} // group C7 

{ vlutw8a ( va7 , vj ) ; 
} // group C8 

{ vlut8a(va7, vi7) ; 
} // group C9 

{ vsldoi(va7, va7 , va7 , 14); 

vlut8a(va6, vi6) ; 
} // group CIO 

{ vsldoi(va6, va6, va6, 12); 

vlut8a (va5 , vi5 ) ; 
} // group Cll 

{ vsldoi(va5, va5, va5, 10); 

vlut8a ( va4 , vi4 ) ; 
} // group C12 

{ vsldoi (va4, va4, va4, 8) ; 

vlut8a(va3, vi3) ; 
} // group C13 

{ vsldoifvaS, va3, va3 , 6); 

vlut8a(va2 f vi2) ; 
} // group C14 

{ vsldoi { va2 , va2 , va2 , 4 ) ; 

vlut8a{val, vil) ; 
} // group CIS 

{ vsldoi (val, val, val 7 2); 



// VSIU computes index for va4 

// VPU rotates va4 left by 8 bytes 

// VLUT writes va3 



// VSIU computes index for va5 

// VPU rotates va5 left by 6 bytes 

// VLUT writes va4 



// VSIU computes index for va6 

// VPU rotates va6 left by 4 bytes 

// VLUT writes va5 



// VSIU computes index for va7 

// VPU rotates va7 left by 2 bytes 

// VLUT writes va6 



// VLUT writes va7 



// VLUT looks up va7 



// VPU rotates va7 left by 14 bytes 
// VLUT looks up va6 



// VPU rotates va6 left by 12 bytes 
// VLUT looks up va5 



// VPU rotates va5 left by 10 bytes 
// VLUT looks up va4 



// VPU rotates va4 left by 8 bytes 
// VLUT looks up va3 



// VPU rotates va3 left by 6 bytes 
// VLUT looks up va2 



// VPU rotates va2 left by 4 bytes 
// VLUT looks up val 



// VPU rotates val left by 2 bytes 
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vlut8a(va0 / viO) ; 
} // group CI 6 



// VLUT looks up vaO 



[00317] Figures 75 - 78 shows methods to transpose a matrix where each row of 
the matrix can be loaded into a vector register. In order to transpose a matrix of a 
dimension such that a vector register is not large enough to hold an entire row of the 
matrix, the matrix is split into blocks (e.g., 16x16 8-bit blocks, or 8x8 16-bit blocks, 
or 4x4 32-bit blocks) so that each row of the blocks can be loaded into a vector 
register. Each block of the matrix can be transposed using the methods according the 
present invention and stored in an transposed order of the matrix. 
[00318] While Figures 75 - 76 illustrate a method to transpose a square matrix, 
the methods shown in Figures 77 - 78 can also be used to transpose other 
rectangular matrices. 

[00319] In one embodiment of the present invention, the transposition of a matrix 
of 16x16 8-bit elements takes only 32 cycles; and the transposition of a matrix of 
8x8 16-bit elements takes only 16 cycles. When a series of vector merge instructions 
is used in same processor, the transposition of a matrix of 16x16 8-bit elements takes 
64 cycles; and the transposition of a matrix of 8x8 16-bit elements takes 24 cycles. 
Thus, the methods according to the present invention significantly increase the 
efficiency in transposing matrices, so that they are faster than other software 
implementations and more flexible than solutions based on dedicated hardware. The 
matrix transposition methods according to the present invention can be used to 
transpose matrices of various dimensions, as well as matrices with elements of 
various sizes (e.g., 8-bit , 16-bit, 32-bit or 64-bit elements). 
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[00320] At least one embodiment of the present invention seeks to utilize Vector 
Look Up Unit (VLUT) to convert color components in one color space (e.g., YCrCb, 
RGB, YUV, YIQ, HSI, HSV, HLS or others) into color components in another color 
space. 

[00321] Color space conversion may be based on a linear transformation. For 
example, 

Y = 0.257 R + 0.504 G + 0.098 B + 16 
Cb = -0.148 R - 0.291 G + 0.439 B + 128 
Cr = 0.439 R - 0.368 G - 0.071 B + 128 

[00322] However, color space conversion may also be based on a nonlinear 
transformation, such as 

Y = fll(R) + f 12(G) + f 13(B) + fl 
Cb = f21(R) + f 22(G) + f 23(B) + f2 
Cr = f31(R) + f32(G) + f33(B) + f3 

[00323] The partial components (e.g., 0.257 R, or 0.439 B, or f32(G), or f3 ) of 
the new components can be computed algebraically. The partial components may 
also be looked up from a set of look up tables and be summed up as the new 
components. 

[00324] The constant partial components may be incorporated into the other 
partial components, such that 

Y = gll(R) + gl2(G) + gl3(B) 
Cb = g21(R) + g22(G) + g23 (B) 
Cr = g31(R) + g32(G) + g33 (B) 
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[00325] Figure 90 shows an example of a method to convert a vector of elements 
into another vector of elements using a vector look up unit according to one 
embodiment of the present invention. The components (e.g., RGB) of a color stored 
in a vector register are used as indices 4401 to look up partial components. Index 
4402 is used to look up the constant terms of the transformation. Indices 4401 are 
replicated (e.g., using a vector permutation operation) to generate indices 4403, 
4405, and 4407 for looking up the partial components for all the new components 
(e.g., YCrCb). For example, a RGB color is converted into a YCrCb color. Since a 
color in a YCrCb space has only 3 components, look up tables 4441 are not used. 
Look up tables 4443 contain partial components (including the constants) for the Y 
component; look up tables 4445 contain partial components (including the 
constants) for the Cb component; and look up tables 4447 contain partial 
components (including the constants) for the Cr component. The partial components 
4413, 4415, and 4417 are looked up simultaneously from a vector look up unit 
according to the present invention. For example, data 4461 equals to partial 
component fll(R); data 4462 equals to partial component fl2(G); data 4463 equals 
to partial component fl3(B); and data 4464 equals to partial component fl. The 
partial components are summed up (e.g., using a vector sum across partial 
instruction) to produce the color components 4423 (Y), 4425 (Cb), and 4427 (Cr). 
For example, component 4423 equals fl l(R)+fl2(G)+fl3(B)+fl=Y. In one 
embodiment of the present invention, the summations 4453, 4455, 4457, and 4451 
are performed using a vector sum across partial instruction in a Vector Complex 
Integer Unit (e.g., VCIU 2810 in Figure 18). Although Figure 90 illustrates an 
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example where index 4402 is zero, index 4402 can take any other value when the 
entries of corresponding look up table (e.g., LUT3, LUT7 and LUT1 1) indexed by 
that value have the constant partial components for the transformation. When all the 
entries in each of the look up tables for looking up the constant partial components 
are filled with the corresponding constants, the value of the index 4402 can be 
arbitrary. 

[00326] To compute all three color components using a linear transformation, 9 
multiplications and 9 additions are required. However, when the method as shown in 
Figure 90 is used, the new components can be computed using three vector 
operations (e.g., a vector permutation operation to compute indices 4403 - 4409, a 
vector table look up operation to look up partial components 4413 - 4417, and a 
vector sum across partial operation to add up partial components into components 
4423 - 4427). Further, these vector operations may be run in parallel in different 
execution units to provide one color conversion per cycle throughput. More details 
are described below. 

[00327] The computed components 4423 - 4427 may be further clamped to the 
maximum dynamic range (e.g., from -128 to 127) and represented as 8-bit data. 
Alternatively, the computed components may be stored with extended precision for 
further manipulations. 

[00328] In Figure 90, look up tables for all the partial components for converting 
a color can be loaded into a vector look up unit. Thus, after a vector look up unit is 
loaded with the look up tables, all new components for a set of pixels can be 
computed in a single pass without having to reload the vector look up unit. However, 
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when partial components of extended precision are used, a vector look up unit may 
not be able to hold all the tables for looking up the partial components. In this case, 
multiple passes are necessary. In each of the passes, a subset of the look up tables is 
loaded into the vector look up unit to compute one or more new components for the 
set of pixels. The constant partial components may be combined with other non- 
constant partial components or be added during the summation stage to reduce the 
required number of look up tables, especially when extended precision is used. 
[00329] Figure 91 shows an example of a method to convert a vector of elements 
into another an element of another vector using extended precision in a vector look 
up unit according to one embodiment of the present invention. The indices 4501 are 
replicated as indices 4503, 4505, 4507 and 4509 for looking up the bytes of the 
partial components of extended precision. For example, indices 4503 are used in 
look up tables 4543 for looking up a 4-byte partial component 4513 (P0). Byte 4541 
from look up table LUT0 in 4543 is the first byte of P0; byte 4543 is the second 
byte; byte 4545 is the third byte; and byte 4547 is the forth byte of P0. Similarly, 
partial component 4515 due to the G component is looked up from look up tables 
4545; and partial component 4547 due to the B component is looked up from look 
up tables 4547. The constant 4519 of the transformation is looked up from tables 
4549. When all the entries of the each of tables 4549 takes the same value, index 
4502 can be arbitrary. Vector sum across operation 4521 sums the partial 
components 4513-4519 into a component (4523) of extended precision. To convert 
RGB components for a set of pixels into YCrCb components, the look up tables 
4543 - 4549 are first loaded with the look up tables for the partial components for 
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the Y component. A loop can be used to compute the Y components for the set of 
pixels in a one pass. Then, the look up tables for the Cb components can be loaded; 
and a loop can be used to compute the Cb components for the set of pixels another 
pass. Finally, the Cr components can be computed in the same fashion. 
[00330] Figure 90 and Figure 91 illustrate the methods for converting RGB color 
components into YCrCb components. It will be appreciated that these methods can 
also be applied to the conversion of color components between other color spaces 
(e.g., from RGB to YUV, or from YUV to HSV). In a 128-bit vector processor, it is 
possible to look up 16 8-bit numbers, 8 16-bit number, 5 24-bit numbers or 4 32-bit 
numbers in parallel. If less precision is required, more elements can be processed in 
parallel. Thus, in a 128-bit vector processor, four new components may be computed 
from 8-bit partial components after a single vector look up operation; two new 
components may be computed from 16-bit partial components in extended precision 
after a single vector look up operation; and one component may be computed from 
24-bit or 32-bit partial components in extended precision after a single vector look 
up operation. When extended precision is used, not all components can be computed 
in a single vector look up operation. It is necessary to reload (update) the look up 
tables for the computation of the other components. The computed components may 
be packed into various different formats, such as packing each components into a 
separate frame buffer, or interleaving components into a single buffer (e.g., 
interleaved CrYCbY in 4:2:2 CCIR 601 frame buffer, or interleaved YCrCbX 4:4:4 
format). The computed components can either be stored with extended 32-bit 
precision for further manipulations or be scaled and clamped to the 8-bit dynamic 



04860.P2687 



124 



range. Any output packing can be achieved by applying vector permutation 
operations on the pixel components. Different components may be computed using 
partial components of different precisions. For example, the Y components may be 
computed using 32-bit partial components in one pass; and the Cb and Cr 
components may be computed using 16-bit partial components in another pass. 
[00331] It will be appreciated that the above method can also be used to convert 
other types of vectors, whenever the new components can be expressed as sums of 
partial components. 

[00332] Figure 92 shows a flow chart for a method to convert a vector of 
elements into another vector of elements using a vector processor according to one 
embodiment of the present invention. After the look up tables in a vector look up 
unit are updated for the partial components, operation 4601 loads the components of 
a first vector (e.g., RGB components of a pixel, or XYZ components of a position 
vector) into a vector register. Operation 4603 generates a vector of indices from the 
components of the vector. Operations 4603 may be performed using a vector 
permutation operation or other vector restructuring operations than can replicate 
indices in a vector register. Operation 4605 looks up simultaneously a plurality of 
data items from the look up tables using the vector of indices. The plurality of data 
items comprises partial components of the components of a second vector. Operation 
4607 sums the partial components to produce at least one component for the second 
vector. Operation 4607 may be performed using a vector sum across partial 
instruction or a vector sum across instruction. Operation 4609 stores the computed 
components in a desirable format in memory. It will be appreciated that operations 



04860.P2687 



125 



4601 - 4609 may be repeated for computing a subset of components for a plurality of 
vectors, before the look up tables are updated for computing another subset of 
components of the plurality of vectors. Thus, when the color space conversion must 
achieve high precision for high quality results, all components of a set of pixels may 
be computed in two or three passes. 

[00333] Figure 93 shows a flow chart for a method to convert a vector of 
elements into another vector of elements using a VLIW processor according to the 
present invention. While VLUT looks up partial components for pixel n+2 in 
operation 4625, VCIU may be concurrently used to sum across (or sum across 
partially) the partial components for pixel n+1; VPU may compute indices for 
looking up partial components for pixel n+2; and LSU may store computed 
components for pixel n. Thus, a number of execution units can process in parallel to 
compute components of a vector using a transformation defined by a set of look up 
tables. 

[00334] The above methods according to the present invention greatly accelerate 
the speed for Color Space Conversion (CSC). The programmability of the VLIW 
engine allows the CSC methods according to the present invention to accommodate 
various pixel input/output formats (packing formats), clamping modes and dynamic 
range manipulations. When the CSC is applied at the last stage of a video processing 
pipeline prior to display, the pixels must be scaled and clamped back to their native 
dynamic range. When the CSC is applied during some intermediate stage of image 
composition output pixels may be kept with extended precision in order to achieve 
higher quality of composition results. Since the CSC methods according to the 
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present invention can be carried out using memory-to-memory operation, they can 
be used in any stage in the video-processing pipeline. Further, the CSC methods 
according to the present invention provide the flexibility with respect to the trade off 
between precision and speed: a higher computation speed can be achieved by 
requesting less precision in the result, and higher precision in the result can be 
achieved with a slower computation speed. 

[00335] It will be also appreciated that the color transformation defined by the 
look up tables can also incorporate other factors, such as gamma corrections. The 
look up tables can also be used to represent nonlinear color transformation, which 
may be used to matching the colors on a display device to that in a printing device, 
etc. 

[00336] At least one embodiment of the present invention seeks to utilize a vector 
look up unit to blending images efficiently. 

[00337] For all algebraic definitions of blending factors Kl and K2, except those 
which are functions of both alphal and alpha2, a one dimensional lookup table 
(LUT) with either 256 or 1024 entries can be pre-calculated for 8-bit or 10-bit keys. 
Using look up tables to compute blending factors has the benefit that all types of 
blending operation that can be expressed in the form of the general blending 
equation have deterministic performance. Also, the LUT operation is always faster 
than computing blending factors algebraically for each attribute of each pixel (a 
requirement of sequential planar processing). Further, the entries of the look up table 
can be stored as floating point numbers to eliminate the operation to convert integer 
"keys" to floating point numbers. Arithmetic of various precisions, such as 32-bit 
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floating point arithmetic or 16-bit fixed point arithmetic, may be used for different 
performance-quality tradeoffs. Alternatively, the entries of the look up table can be 
stored as fixed point numbers or integers. 

[00338] The look up units in a vector look up unit (VLUT) can be configured into 
a plurality of look up tables. For example, in a 128-bit vector processor, a VLUT can 
be configured into 16 look up tables of 8-bit data entries indexed by 8 bit indices. A 
number of the look up tables can be used to store different bit segments of a data 
item of extended precision. For example, three of the look up tables may be used to 
store the first, second, and third bytes (i.e., bits 0-7, 8-15 and 16-23) of 24-bit data 
items. An 8-bit index can be replicated for the three look up tables to look up 
simultaneously the first, second, and third bytes of a data item indexed by the 8-bit 
index. Thus, 16 look up tables can be used to look up simultaneously 16 8-bit data 
items, or 8 16-bit data items, or 4 32-bit data items, etc. Further, the look up tables 
can be arranged in such a way that bytes of data items of extended precision looked 
up from a VLUT are properly aligned in a vector register. 
[00339] Figure 79 shows an example of a method to look up a vector of data 
items of extended precision according to one embodiment of the present invention. 
Indices 9910 are a portion of the indices in a vector register. Indices 9910 may be 
replicated as indices 9920 using a vector operation (e.g., using a vector merge 
operation or a vector permutation operation). Every index in indices 9910 is 
replicated multiple times for looking up multiple bytes of the data items from the 
look up tables in the vector look up unit. For example, index 9901 (B0) is replicated 
as indices 9911 and 9912 for look up tables 9951 (LUT0) and 9952 (LUT1) to look 
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up bytes 9931 (DOh) and 9932 (DOl) of a data item. Since LUT1 contains the higher 
bytes of the data items, and LUT2 contains the lower bytes of the data items, DOh 
and DOl represent a correctly aligned 2-byte data item. Similarly, index 9908 is 
replicated as indices 9921 and 9922 to look up a data item with bytes 9941 and 9942 
looked up respectively from tables 9961 and 9962. Similarly, indices 9909 may be 
replicated to look up another vector of 16-bit data items from the look up tables. 
[00340] Although Figure 79 illustrates an example of looking up 2-byte data 
items using a vector look up unit, it will be appreciated that the method can be used 
to look up data items of other extended precision, such as 24-bit or 32-bit data. 
[00341] Loading the look up units of a VLUT is a time-consuming operation, 
which should be avoided wherever possible while processing an image. The look up 
tables of blending factors for the first and second images can be loaded sequentially 
into a VLUT for converting a set of keys into blending factors. However, one 
operation for loading tables into the VLUT can be eliminated by loading half of the 
look up tables with blending factors for the first image (e.g., Kl), and the other half 
of the look up tables for the second image (e.g., K2). Thus, vectors of blending 
factors for the first and second image can be looked up in parallel. Further, when the 
look up tables for the blending factors for both the first and second images of a 
frame are loaded in a VLUT, subsequent table loading operations may be eliminated 
if the same set of keys can be used for blending the subsequent frames of images. 
[00342] Figure 80 shows an example a method to look up two vectors of data 
items in parallel for one vector of indices according to one embodiment of the 
present invention. A vector of indices 41 10 is replicated as two groups of indices 
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4120 and 4130. Each group of indices looks up a vector of data items. For example, 
indices 4120 are used in look up tables 4191 to look up data items 4140; and indices 
4130 are used in look up tables 4193 to look up data items 4181. Similarly, indices 
4109 may be used to look up data items 4150 from tables 4191 and data items 4182 
from tables 4193. Data 4140 and 4150 can be packed into a vector register as data 
4160 and 4170 looked up from tables 4191; and data 4181 and 4182 can be packed 
into a vector register as data 4183 and 4184 looked up from tables 4193. Thus, a 
vector of indices is used to look up two vectors of data items in parallel from two 
sets of look up tables. Note that indices 4110 and 4109 may be used in a single look 
up operation to obtain data 4160 and 4170, if tables 4191 are replicated in the place 
of tables 4193 (LUT8 - LUT15). However, in such an approach, it is necessary to 
load tables 4193 (in LUT0 - LUT15) after looking up 4160 and 4170 in order to look 
up data 4183 and 4184, which leads to an extra operation for loading look up tables. 
[00343] In one embodiment of the present invention, tables 4191 are loaded with 
entries for looking up the blending factors for the first image (e.g., Kl); and the 
tables 4193 are loaded with entries for looking up the blending factors for the second 
image (e.g., K2). Thus, the blending factors for both images are looked up 
simultaneously. Although, Figure 80 illustrates an example where the blending 
factors for different images are separated in groups 4140 and 4181, the look up 
tables and the replication of indices may be arranged such the blending factors for 
the first and the second images are stored in an interleaved format in a vector register 
after the look up operation (e.g., when the look up tables are interleaved and the 
indices are replicated in a fashion as in Figure 79). 
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[00344] Figure 81 shows an example of a method to look up two vectors of data 
items in parallel for two vectors of indices according to one embodiment of the 
present invention. Indices 4201 and 4203 from two different vectors are replicated as 
indices 4205 and 4215 for look up tables 4207 and 4217 to look up data 4209 and 
4219. Similarly, indices 4211 and 4213 are used in tables 4207 and 4217 
respectively to look up data 4231 and 4232. Data 4209 and 4231 can be packed into 
a vector register as data 4233 and 4234 looked up from tables 4207; and data 4219 
and 4232 can be packed into a vector register as data 4235 and 4236 looked up from 
tables 4217. 

[00345] For some types of blending, Kl is a function of alphal while K2 is a 
function of alpha2, or vice versa. To avoid table reloads, in one embodiment of the 
present invention, tables 4207 are used to convert alphal to Kl and tables 4217 are 
used to convert alpha2 to K2. Thus, two vectors of keys are used to generate indices 
to look up in parallel two respective vectors of blending factors for the two images. 
[00346] It will be appreciated that the methods illustrated in Figure 79 and 
Figure 80 (or Figure 81) may be combined to look up two vectors of data of 
extended precision in parallel. Figure 82 shows an example of a method to look up 
two vectors of data items of extended precision in parallel for one vector of indices. 
Indices 4241 are replicated as indices 4243 for looking up data items of extended 
precision. Part of indices 4243 is replicated as indices 4245 and 4244 for look up 
tables 4247 and 4246 to look up vectors 4249 and 4248. Note that indices 4245 and 
4244 can be produced from indices 4241 using a single vector permutation 
operation. 
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[00347] Figure 83 shows another example of a method to look up two vectors of 
data items of extended precision in parallel for one vector of indices according to 
one embodiment of the present invention. Index 4260 of indices 4251 is replicated as 
indices 4255 for look up tables 4257 to look up two data items of extended 
precision. Bytes 4261 and 4262 are the higher and lower 8-bits of the data item 4259 
for the first output vector; and bytes 4263 and 4264 are the higher and lower 8-bits 
of the data item for the second output vector. Similarly, date items 4275 - 4277 are 
for the first output vector. The date items for the first and the second output vectors 
are interleaved in the vector register after the look up operation. To separate the first 
and second output vectors, vector restructuring instructions (e.g., a vector packing 
instruction or a vector permutation instruction) may be used to pack the data items of 
output vectors into separate vector registers. For example, date items 4259, 4275 - 
4277 may be packed into a vector 4265. The date items looked up using two groups 
of indices (e.g., indices 4251 and 4252) can be packed into two vector registers. 
[00348] From the above description, it would be apparent to those skilled in the 
art that the look up tables may be arranged in a VLUT in a variety of way to 
produces two output vectors in a variety of formats (e.g., interleaved or grouped in 
certain fashion) after a vector look up operation. 

[00349] Figure 84 shows a method to blend two images using a vector look up 
unit according to one embodiment of the present invention. After the look up tables 
for the blending factors are loaded into the vector look up unit, operation 4301 
converts keys for a set of pixels into blending factors using the vector look up unit. 
For example, the keys for the pixels in a frame may be stored in a buffer, named 



04860.P2687 



132 



alpha plane. In some embodiment, two alpha planes (alphal and alpha2) are used for 
determining the blending factors for each of the two source images. Operation 4301 
converts the alpha plane (or alpha planes) into blending factor planes (buffers for 
blending factors) using a vector look up unit. The blending factors for the source 
images may be looked up sequentially, or may be looked up in parallel using the 
methods illustrated in Figures 79 - 83. Operation 4303 blends an image attribute 
(e.g., Y plane using blending factor planes). Optionally, operation 4305 subsamples 
the blending factors when different image attributes have different sample rates. For 
example, to blending 4:2:4 YCrCb video images, the blending factors for a Y plane 
may be subsampled before blending a Cr or Cb plane. Operation 4307 blends the 
other image attributes using the blending factors. The blending factors for different 
images may be stored in different planes (buffers), the blending factors may also be 
stored in a single buffer in an interleaved format. 

[00350] In one embodiment of the present invention, a multiply accumulate loop 
is used to compute the blended image attribute using the blending factors and the 
images attributes from the two source images. Floating point operations are used; 
and four components per vector may be processed on a 128-bit vector processor. The 
resulting image attributes are converted from floating point numbers to integer 
numbers before being stored into host memory. 

[00351] Figure 85 shows a method to look up vectors of blending factors using a 
vector look up unit according to one embodiment of the present invention. Operation 
431 1 loads a vector of keys into a vector register. Operation 4313 looks up 
simultaneously a first vector of blending factors for the first image and a second 



04860.P2687 



133 



vector of blending factors for the second image for the vector of keys. The blending 
factors for the first and second images may be interleaved in a vector register, or 
may be separated in two groups in a vector register. The blending factors for 
different images may be stored in different buffers as separate planes of blending 
factors, or be stored in a buffer in an interleaved format. The blending factors looked 
up from the look up tables may be floating point numbers, or may be numbers of 
extended precision (e.g., 16-bit fixed point numbers or 32-bit floating point 
numbers). 

[00352] Figure 86 shows a method to look up two vectors of data items using 
two vectors of indices. Operation 4321 generates a third vector of indices by 
selecting and replicating a subset of elements from the two vectors of indices. 
Operation 4323 looks up simultaneously a plurality of data items from a plurality of 
look-up tables in the vector look up unit indexed by the third vector of indices. The 
plurality of data items comprises the data items of two vectors of data items, 
corresponding to the indices replicated from the two vectors of indices respectively. 
The data items for the two vectors of data items may be interleaved, or grouped into 
separate groups, or packed in other formats in a vector register. The two vectors of 
indices may be two different vectors, or may be the same vector. The method shown 
in Figure 86 may be used to convert keys to blending factors. 
[00353] Figures 87 - 89 show flow charts for methods to look up two vectors of 
data items in parallel for one or two vectors of indices. 

[00354] In Figure 87, after operation 433 1 loads a first vector of indices into a 
vector register, operation 4333 merges a first half of the first vector of indices with 
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itself to generate a second vector of indices (in a fashion illustrated in Figure 79). 
Operation 4435 looks up simultaneously a first vector of data items from a plurality 
of look-up tables in a vector look up unit indexed by the second vector of indices. 
Optionally, operation 4337 stores the first vector of data items into memory. 
Similarly, operations 4339 - 4343 look up a second vector of data items from using 
the second half of the first vector of indices. The method in Figure 87 can be used to 
look up two vectors of data items of extended precision, or two interleaved vectors 
of data items, which may be repacked into two new vectors. The merging operations 
(in operations 4333 and 4339) may be performed using vector merge instructions, or 
vector permutation instructions, or other vector restructuring instructions. 
[00355] In Figure 88, after operation 4351 loads a first vector of indices into a 
vector register, operation 4353 generates a second vector of indices by replicating a 
first half of the first vector of indices to replace a second half of the first vector of 
indices (in a fashion illustrated in Figure 80). Operation 4355 looks up 
simultaneously a first vector of data items from a plurality of look-up tables in a 
vector look up unit indexed by the second vector of indices. Similarly, operations 
4357 and 4359 look up a second vector of data items using a second half of the first 
vector. Operation 4361 packs the first halves of the first and second vectors of data 
items into a third vector of data items; and, optionally, operation 4363 stores the 
third vector of data items into memory. Similarly, operation 4365 packs the second 
halves of the first and second vectors of data items into a forth vector of data items; 
and, optionally, operation 4367 stores the forth vector of data items into memory. 
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[00356] In Figure 89, after operations 4371 and 4373 load first and second 
vectors of indices into vector registers, operation 4375 generates a third vector of 
indices by replicating a first half of the second vector of indices to replace a second 
half of the first vector of indices (in a fashion illustrated in Figure 81). Operation 
4377 looks up simultaneously a first vector of data items from a plurality of look-up 
tables in a vector look up unit indexed by the third vector of indices. Similarly, 
operations 4379 and 4381 looks up a second vector of data items using second 
halves of the first and second vectors of indices. Similar to operations 4361 - 4367, 
operations 4383 - 4389 repack the first and second vectors of data items into third 
and forth vectors of data items, corresponding respectively to the first and second 
vector of indices. 

[00357] From the above description, it would be apparent to those skilled in the 
art that a variety of variations of the methods in Figures 87 - 89 can be used to look 
up two vectors of data items of extended precision (e.g., 16-bit, 24-bit, or 32-bit data 
items) in parallel for one or two vectors of indices. 

[00358] At least one embodiment of the present invention seeks to decode a bit 
stream using Very Long Instruction Word (VLIW) processing engines. Each VLIW 
engine (e.g., engine 2800 in Figure 18) comprises a number of execution units, such 
as Integer Arithmetic Logical Unit (e.g., IALU 2805), Integer Shift Unit (e.g., ISHU 
2806), Load Store Unit (e.g., LSU 2816), Vector Permute Unit (e.g., VPU 2808), 
Vector Simple Integer Unit (e.g., VSIU 2809), Vector Complex Integer Unit (e.g., 
VCIU 2810), Vector Look Up Table Unit (e.g., VLUT 2811), and Branch Unit (e.g., 
BRU 2824). The execution units can process information in parallel, and VLUT can 
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perform variable length decoding very efficiently. Thus, various methods according 
the present invention can be used to decode bit streams efficiently. 
[00359] While a DV video stream is used to illustrate various methods of 
decoding a bit stream using VLIW processing engines, it will be appreciated that 
various method illustrated here may also be applied to decoding other bit streams, 
such as video streams encoded using various MPEG standards or images in JPEG 
standards. 

[00360] Due to the limited amounts of local memory and instruction cache 
available on a processing engine, multiple stages of decoding may be utilized to 
reduce the requirement on the local memory and eliminate the instruction cache 
misses. In each stage, only the instructions and data required to perform the 
operations in that stage is loaded into a processing engine. The command queue 
mechanism described earlier can be used to maintain a multi-stage frame decode 
operation since the processing engine is capable to reload execution environments 
(instructions and arguments) autonomously without the intervention from the host 
software. Each stage is a memory to memory operation, in which the instructions 
and data are loaded from the host memory into the processing engine, and the 
processing results are transferred back from the local memory of the processing 
engine to the host memory. 

[00361] Figure 63 shows a flow diagram for a method to decode a D V video 
stream in one stage. In operation 8301, the input bit stream is loaded into the local 
memory (e.g., local memory 2817 in Figure 18) of a processing engine (e.g., 
processing engine 2800). In a single stage 8312, operations 8302 - 8304 decode the 
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input bit stream to generate a decompressed video stream. Operation 8302 performs 
Macro Block Address Generation (MBAG); operation 8303 performs Variable 
Length Decoding (VLD); and operation 8304 performs Inverse Discrete Cosine 
Transformation (IDCT). The resulting decompressed video stream is buffered in the 
local memory and is output from the local memory in operation 8305 for display or 
for further processing. In one example, the input bit stream is a standard DV bit 
stream at 25 Mbits/sec (SMPTE 316M). The output video stream is YUV frames of 
4:1:1 sampling structure at 16Mbytes/sec. Since a YUV frame is stored in a planar 
format where separate pixel components are stored in separate frame buffers in the 
system memory, the chrominance up sampling and luminance/chrominance 
interleaving operation is offloaded from the decoder. The bandwidth required to 
transfer data between the processing engine and the host memory is about 20 
Mbytes/sec. Since all intermediate results are stored on the local memory, the single 
stage approach requires least bandwidth. However, since instructions for processing 
all the operations (i.e., MBAG 8302, VLD 8030 and IDCT 8304) must be loaded 
into the instruction cache, the greatest amount of instruction cache is required, when 
compared to the multi-stage approaches, which will be described below. In one 
embodiment, 8214 bytes of local memory and 8192 bytes of instruction cache are 
required. 

[00362] The compressed macro blocks in a DV bit stream must be decoded into 
two-dimensional blocks of pixels and stored in a pseudo random order specified by 
the DV standard. MBAG computes the correct destination addresses for reordering. 
Macro block addresses may be looked up from a single look-up table. Since a frame 
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of DV25 bit stream contains 1350 macro blocks, a look-up table of 2700 bytes is 
required. Alternatively, macro block addresses may be computed in run time on a 
macro block per macro block basis. Although computing macro block address in run 
time reduces the requirement on the size of the memory, it costs extra time in 
computation. By moving macro block reordering into a separate stage, while using a 
look-up table for MB AG, it is possible to reduce the overall requirement for memory 
without extra computation cost. 

[00363] Figure 64 shows a flow diagram for a method to decode a DV video 
stream (e.g., a frame of a DV video image) in two stages. In operation 8401, the 
input bit stream is loaded into the local memory of a processing engine. In stage 
8412, operation 8402 performs Macro Block Address Generation (MBAG). Only the 
instructions for MBAG is required to be loaded into the instruction cache. In stage 
8412, macro block addresses are calculated and stored in the first two bytes of 
Digital Interface (DIF) block headers to generate a modified DV bit stream. In 
operation 8403, the modified DV bit streams are transferred from the local memory 
into the host memory after MBAG is performed and are transferred back into the 
local memory for the operations in stage 8414. In stage 8414, VLD 8404 and IDCT 
8405 are performed to generate a decompressed video stream. In stage 8414, only 
the instructions for performing VLD and IDCT are loaded into the instruction cache. 
The resulting decompressed video stream buffered in the local memory is output 
from the local memory in operation 8406. Since the look up table for performing 
MBAG is not required in this stage for VLD and IDCT, the requirement on the size 
of the local memory can be reduced. In one implementation, 5514 bytes of local 
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memory and 8192 bytes of instruction cache are required. However, the modified 
DV bit stream is transferred from the local memory to the host memory and then 
back to the local memory, the required bandwidth is about 26 Mbytes/sec, which is 
slightly higher than that for a single stage approach. However, the extra requirement 
on bandwidth (50 Mbits/sec) is an insignificant amount for any up to date memory 
subsystem. 

[00364] Figure 65 shows a flow diagram for another method to decode a D V 
video stream in two stages. In operation 8501, the input bit stream is loaded into the 
local memory of a processing engine. In stage 8512, operation 8502 performs Macro 
Block Address Generation (MB AG); and operation 8503 performs Variable Length 
Decoding (VLD) to generate coefficients for Inverse Discrete Cosine 
Transformation (IDCT). Inverse zigzagging and inverse scaling are also performed 
in operation 8503. The macro block reordering from DV the pseudo random order to 
the sequential raster scan order is performed at stage 8512. In Operation 8504, the 
IDCT coefficients are transferred from the local memory into the host memory after 
VLD are performed and are transferred into the local memory from the host memory 
to perform operations in stage 8514. In stage 8514, IDCT 8405 is performed to 
generate a decompressed video stream which is buffered in the local memory. The 
decompressed video stream is transferred from the local memory in operation 8506. 
Since the two major operations, i.e., VLD and IDCT, are separated in two stages, the 
requirement on the size of the instruction cache can be reduced. In one 
implementation, 4096 bytes of instruction cache and 9104 bytes of local memory are 
required. However, the IDCT coefficients are transferred from the local memory to 
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the host memory and then back to the local memory, the required bandwidth is about 
83.5 Mbytes/sec, which is higher than that for a single stage approach. 
[00365] Figure 66 shows a flow diagram for a method to decode a DV video 
stream in three stages. In operation 8601, the input bit stream is loaded into local 
memory of a processing engine. In stage 8612, operation 8502 performs Macro 
Block Address Generation (MB AG) to calculate macro block addresses which are 
stored in the first two bytes of Digital Interface (DIF) block headers in a modified 
DV bit stream. In operation 8603, the modified DV bit streams are transferred out of 
the local memory into the host memory after MB AG is performed and are 
transferred back into the local memory to perform operations in stage 8614. 
Operation 8604 performs Variable Length Decoding (VLD) to generate coefficients 
for Inverse Discrete Cosine Transformation (IDCT). Inverse zigzagging and inverse 
scaling are also performed in operation 8604. In Operation 8605, the IDCT 
coefficients are transferred out of the local memory into the host memory after VLD 
are performed and are transferred back into the local memory to perform operations 
in stage 8616. In stage 8616, IDCT 8606 is performed to generate a decompressed 
video stream. The resulting decompressed video stream buffered in the local 
memory is output from the local memory in operation 8607. Since the two major 
operations (VLD and IDCT) are separated in two stages, the requirement on the size 
of the instruction cache can be reduced. Since the look up table for performing 
MB AG is not required in the stages for VLD and IDCT, the requirement on the size 
of the local memory can also be reduced. In one implementation, only 4096 bytes of 
instruction cache and 6394 bytes of local memory are required. However, since 



04860.P2687 



141 



intermediate results are transferred from the local memory to the host memory and 
then back to the local memory, the required bandwidth is up to about 90 Mbytes/sec. 
[00366] Although Figures 64 - 66 illustrate the multi-stage approaches using a 
single processing engine, it will be appreciated that the various stages may be 
performed in different processing engines to achieve parallel processing using 
multiple processing engines. In such cases, a interconnect (e.g., 1519 in Figure 5B) 
may be used to transfer the data between processing engines. The bandwidth 
required for accessing the host memory may be reduced. 

[00367] The local memory may buffer only a portion of the results generated in 
operations in a stage. The buffered result may be transferred out of the local memory 
before other portions of the results are generated, or concurrently while other 
portions of the results are generate. Similarly, the portions of input data may be 
concurrently transferred into the local memory while other input data are being 
processed. Detailed examples of various schemes for managing the local memory 
are described below. 

[00368] Figure 67 shows a detailed flow diagram for a method to transfer data 
while decoding a video stream. Variable length decoding and inverse discrete cosine 
transforming are performed in the same stage. Operation 8701 variable length 
decodes a video segment which comprises five macro blocks. Operations 871 1 - 
8715 perform inverse discrete cosine transform on the blocks of macro blocks in the 
video segment. While IDCT is performed for the macro blocks in operations 871 1 - 
8715, a Direct Memory Access channel (DMA 0) loads into the local memory, in 
operation 8703, the next compressed video segment which is to be decoded by 
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operation 8701. Operation 871 1 performs IDCT to generate a decompressed video 
stream from the first macro block in the video segment. While operations 8712 and 
8713 perform IDCT on other two macro blocks, a number of DMA channels are 
used to transfer the decompressed video data from the local memory to the host 
memory. For example, DMA 1 is used to transfer the luminance data, while DMA 2 
is used to transfer the chrominance data. Similarly, DMA 3 and DMA 4 are used to 
transfer the luminance and chrominance data for the second macro block. After the 
video images from the third macro block are generated from operation 8713 and the 
video images for the first macro block are transferred into the host memory in 
operation 8721, operation 8723 starts to transfer the video data for the third macro 
block to the host memory. Operations 8724 and 8725 transfer the video images for 
the forth and fifth macro blocks, which may be performed concurrently while 
operation 8701 variable length decodes the next segment. 
[00369] Figure 68 shows a detailed flow diagram for a method to transfer data 
while variable length decoding a current segment of a video stream. Variable length 
decoding is performed in a separate stage, starting with operation 8801. As in 
Figures 65 and 66, while operations 8811 - 8815 decode a video segment, DMA 0 
transfers the next segment into the local memory in operation 8803, and DMA 1 
transfers the IDCT coefficients for the previous segment from the local memory into 
the host memory in operations 8821 - 8825. For example, while pass 1 and pass 2 
variable length decoding is performed on the first macro block in the current 
segment in operation 881 1 , the IDCT coefficients of the first macro block in the 



04860.P2687 



143 



previous segment are transferred into the host memory in operation 8821. Similarly, 
operations 8812 - 8815 are performed in parallel with operations 8822 - 8825. 
[00370] Figure 69 shows a detailed flow diagram for a method to transfer data 
while inverse discrete cosine transforming macro blocks of a video stream. IDCT is 
performed in a separate stage as in Figures 65 and 66. While operation 8905 
performs IDCT to generate decompressed video data for current macro blocks, 
operation 8903 outputs the previously decompressed video data for the previous 
macro blocks, and operation 8901 inputs the IDCT coefficients for inverse discrete 
cosine transforming subsequent macro blocks. 

[00371] A number of buffers may be allocated on the local memory for the 
storage of data for the operations in a stage. The usage of the buffers can be carefully 
scheduled to reduce the requirement on the size of the local memory. 
[00372] Figure 70 shows a memory management scheme for a method to transfer 
data while decoding a video stream. Variable length decoding and inverse discrete 
cosine transforming are performed in the same stage as in Figures 63 and 64. Thus, 
buffers for the compressed bit stream and uncompressed video data are needed. 
Buffer 9001 for compressed bit stream is read during operation 9051 for VLD. 
During operation 9053, DMA 0 loads a compressed bit stream into buffer 9001, as in 
operation 8703. Buffers 9002 - 9006 are for the IDCT operations. In one 
implementation, buffer 9001 can hold a compressed video segment (e.g., 400 Bytes); 
and each of the IDCT buffers (9002 - 9006) can hold a uncompressed video data for 
a macro block (e.g., 768 bytes). IDCT coefficients generated after VLD operations 
9011 - 9015 are stored into the corresponding IDCT buffers. IDCT are performed in 
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place, i.e., the generated decompressed video data are stored back into the buffer for 
the corresponding IDCT coefficients. For example, operation 9021 reads IDCT 
coefficients from buffer 9002 and operation 9031 writes the decompressed video 
data generated from the IDCT coefficients back into buffer 9002 to replace the 
corresponding IDCT coefficients. Intermediate results are held in vector register. 
During operation 9041, DMA 1 and 2 transfer the decompressed video data out of 
the buffer, as in operation 8721. Similarly, IDCT coefficients are read in operations 
9022 - 9025 from buffers 9003 - 9006; and the generated uncompressed video data 
are written back into the corresponding buffers in operations 9032 - 9035. DMA 3 
and 4 start to transfer the decompressed video data from buffer 9003 in operation 
9042 while DMA 1 and 2 may still be transferring the decompressed video data from 
buffer 9002. Operation 9044 for transferring the decompressed video data in buffer 
9005 may continue into operation 9046, before the buffer 9005 is used for VLD 
9014. Similarly, the decompressed video data in buffer 9006 is transferred during 
variable length decoding the next segment and before the buffer 9006 is used for 
storing IDCT coefficients. 

[00373] Figure 71 shows a memory management scheme for a method to transfer 
data while variable length decoding a segment of a video stream. Variable length 
decoding is performed in a separate stage as in Figures 65 and 66. Two VLD buffers 
(9101 and 9102) are used. While VLD is performed using the compressed bit stream 
in one of the VLD buffers (e.g., operation 91 1 1 or 9121), DMA 0 loads the next 
compressed bit stream into the other VLD buffer (e.g., operation 91 13 or 9123). Six 
IDCT buffers (9103 - 9108) form a circular queue for buffering IDCT coefficients. 
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In one example, a VLD buffer can hold a compressed video segment (e.g., 400 
Bytes), and each of the IDCT buffers can hold IDCT coefficients for a macro block 
(e.g., 768 Bytes). In pass 1 and pass 2 VLD operations for the macro blocks, the 
IDCT coefficients are written into the corresponding IDCT buffers (e.g., operations 
9131 - 9135). In pass 3 VLD, operations 9161 - 9165 may access all the five buffers 
used in pass 1 and 2 VLD. IDCT coefficients in one IDCT buffer are transferred into 
the host memory using DMA 1 while pass 1 and 2 VLD is using the available IDCT 
buffer. The pointers to the buffers wrap around when they reach the end of the 
queue. For example, while DMA 1 is transferring data from buffer 9103, pass 1 and 
2 VLD are using buffer 9108. After operation 9141, buffer 9103 becomes available. 
Then, pass 1 and 2 VLD may use buffer 9103 while DMA 1 transferring data from 
buffer 9104. In such fashion, the use of the extra IDCT buffer makes it unnecessary 
to wait until the IDCT coefficients in an IDCT buffer is transferred out, before the 
VLD operation for the next compressed bit stream can start. Also, there is a memory 
saving when comparing to full double buffering IDCT coefficients, which requires 
10 IDCT buffers. 

[00374] Figure 72 shows a memory management scheme for a method to transfer 
data while inverse discrete cosine transforming macro blocks of a video stream. 
Inverse discrete cosine transforming is performed in a separate stage. Two IDCT 
buffers (9221 and 9222) are used for IDCT coefficients; and two pixel buffers (9223 
and 9224) are used for decompressed video images. While IDCT operation is 
generating uncompressed video in one of the pixel buffers from the IDCT 
coefficients in one of the IDCT buffers (e.g., 9201 and 9202, or 921 1 and 9212), 
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DMA 0 transfers IDCT coefficients into the other IDCT buffer (e.g., 9203 or 9213), 
and DMA 1 transfers decompressed video data out the other pixel buffer (e.g., 9204 
or 9214). In one implementation, two macro blocks are processed at a time. Thus, 
each IDCT buffer can hold IDCT coefficients for two macro blocks (e.g., 1536 
Bytes); and each pixel buffer can hold decompressed video data for two macro 
blocks (e.g., 768 Bytes). Three DMA channels are used to transferring three pixel 
components (Y, U, and V) into three separate planes in the host memory. 
[00375] The block VLD processing starts with the block DCT mode extraction. 
Block mode processing chooses the mode of the IDCT, the zigzag pattern and the 
inverse scale matrix. IDCT mode is preserved in the unused LSB of the DC term for 
the subsequent usage by the IDCT stage. Inverse zigzag look up tables are used to 
store 16 bit IDCT coefficients within 8x8 IDCT blocks. IDCT coefficients are 
produced in the transposed order to eliminate one transpose operation during IDCT. 
[00376] Figure 73 shows a flow diagram for a method to decode a bit stream by 
using a plurality of execution units concurrently. After variable length decoding a 
first code word in a bit stream loaded in a vector register in operation 9301, 
execution units (i.e., IALU, LSU, or BRU) are used to process the decoded result in 
operations 931 1 - 9317, while a Vector Look Up Table Unit (VLUT) is used to 
decode the next code word in the bit stream. Operation 9313 looks up a coefficient 
for inverse scaling; operation 9315 looks up an inverse zigzag index for storing 
IDCT coefficient in a transposed inverse zigzag order. Operation 9317 computes and 
stores an IDCT coefficient in memory in a fashion suitable for the inverse discrete 
cosine transformation. While other execution units (e.g., IALU, LSU, and others) are 
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performing operations 9313 - 9315, a branch unit (BRU) performs 9323 - 9327 to 
check various conditions which may have been encountered during variable length 
decoding the code word. If an end of block (EOB) condition is encountered, 
operation 9323 branches to handle the EOB condition (e.g., checking for remaining 
bits); if an adjust bit stream (ADBS) condition is encountered, operation 9325 
branches to handle the ADBS condition (e.g., checking for incomplete code bits); 
and if an entry not found (ENF) condition is encountered, operation 9327 branches 
to handle the ENF condition (e.g., error in the bit stream). 
[00377] Since the IDCT coefficients are provided in a transposed form in 
operation 9317, only one transposition per block is required during IDCT. Execution 
units, such as VSIU, VCIU, VPU, and BRU, can be used in parallel, so that IDCT 
may be performed in approximately 120 cycles for a block. 
[00378] In one embodiment of the present invention, a macro block of 
compressed bit stream (e.g., 80 bits) is loaded into a vector register, which can hold 
128 bits, for variable length decoding using a Vector Look Up Table Unit (VLUT). 
The bit stream is right adjusted in the vector register so that the fence bit is always 
zero. When ADBS is encountered during VLD, the vector register contains 
incomplete code bits from the currently decoded block. When EOB is encountered, 
the vector register contains the left over bits from the currently decoded block 
(remaining bits). Remaining bits and incomplete code bits must be stored for pass 2 
and pass 3 VLD. Remaining bits may be concatenated and be saved into an overflow 
buffer; and incomplete code bits may be stored with other block parameters into 
another buffer. Thus, extra space is required for the overflow buffer; and extra time 
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is used to concatenate the remaining bits in a sequential bit stream. Alternatively, 
since EOB and ADBS are mutually exclusive, a same buffer may be used to store 
either remaining bits or incomplete code bits without concatenating. Typically, two 
types of contexts (incomplete code bit context and remaining bit context) are created 
for each block, as a result of pass one VLD. These two types of contexts share the 
same memory space. If the block is completely decoded, including EOB symbol, 
and there is no remaining bits left, no valid context is created. 
[00379] During pass 2 and pass 3 VLD, the incomplete code bits and remaining 
bits are concatenated prior to being variable length decoded. Since inverse scaling is 
performed concurrently with the variable length decoding, it is necessary to use the 
proper inverse scaling parameter when starting pass 2 or pass 3 decoding. The 
inverse quantization parameter is stored in the incomplete code bit context along 
with the incomplete code bits. The pass 2 and pass 3 loops terminate when there is 
no valid incomplete code bit context or no valid remaining bit context left in the 
memory. 

[00380] Figure 74 shows a data structure for storing either a remaining bit 
context or an incomplete code bit context. When EOB or ADBS is encountered, 
remaining bits (RDBITS) or incomplete code bits (ICBITS) are right adjusted in the 
vector register, since the bit stream is right adjusted during variable length decoding 
the bit stream. A flag is stored in byte 9401 to indicate whether the context is a 
remaining bit context or an incomplete code bit context. In one implementation, a 
flag with a value 0 is used for remaining bits; Oxaa for incomplete code bits; and 
Oxff for an invalid context. The number of bits in the bit segment for remaining bits 
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(or incomplete code bits) is store in byte 9402. For incomplete code bits, some 
parameters in the context must be saved for later use, such as the pointers CMPTR, 
ISPTR and IZZPTR and index CMINDX. For the current macro block, CMPTR 
points to the memory (9431) for the storage of the IDCT coefficients; ISPTR to the 
inverse scale look-up table (9433); and IZZPTR to the inverse zigzag look-up table 
(9435). CMPTR is the index which is used with the decoded run to look up an 
coefficient for inverse scaling and an index for storing the IDCT coefficients in a 
transposed inverse zigzag order. As illustrated in Figure 74, CMINDX, CMPTR, 
ISPTR and IZZPTR can be stored in bytes 9413 - 9416. A fixed size buffer area can 
be used for storing the information about both the incomplete code bits and the 
remaining bits. In one embodiment of the present invention, each of the macro 
blocks in an input buffer has a corresponding memory space for the storage of an 
incomplete code bit context or a remaining bit context. When a macro block is 
decoded without remaining bits or incomplete code bits, the corresponding memory 
space is marked invalid; otherwise, a remaining bit context or a incomplete code bit 
context is generated and stored in the corresponding memory space. 
[00381] In one embodiment, there is a constant scaling factor (ISCONST) per 
block. The constant (ISCONST) is computed using class and quantization number 
during block mode processing. The constant scaling factor is combined with the 
scaling factor from a look-up table to determine a final scaling factor. In this case, it 
is necessary to store the constant for pass 2 and 3 VLD. Byte 9417 in an incomplete 
code bit context may be used for storing ISCONST. 
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[00382] It will be appreciate that multiple processing engines can be used in 
decoding multiple bit streams by assigning each of the processing engines to process 
one of the bit streams. Multiple processing engines can also be used in decoding a 
single bit stream (e.g., a high resolution stream) by assigning each of the processing 
engines to process a portion of the bit stream (e.g., portions of a frame). Since the 
granularity of input and output data is a compressed/uncompressed macro block, it is 
easy to equally divide the sequence of compressed macro blocks into equally sized 
subsequences and schedule them to be decoded in parallel on multiple processing 
engines. 

[00383] Various methods described above for decoding a bit stream may also be 
adapted to be used in encoding a video stream (e.g., in a DV format). For example, a 
process of compressing a video stream can also be separated into a plurality stages 
(i.e., a plurality of memory to memory operations). In each stage, a plurality of 
execution units may be configured to processing in parallel with DMA operations, 
which transfer data between the local memory in a processing engine (e.g., memory 
2817 in Figure 18) and the host memory (e.g., memory 1402 in Figure 4A). 
[00384] Figure 94 shows a method to encode a DV video stream in three stages. 
During the first processing stage, called the Forward Discrete Cosine Transformation 
(FDCT) stage, operation 4701 transfers the components (e.g., 4:1:1 YUV 
components) of a frame from host memory (e.g., a buffer for pixel macro blocks 
4711) to the local memory of a processing engine. After FDCT mode selection, 
FDCT, zigzag scan, classification and initial scaling, operation 4702 transfers the 
resulting 16-bit scaled FDCT coefficients for the macro blocks from the local 
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memory back to the host memory (e.g., a buffer for FDCT coefficients 4712). The 
FDCT macro blocks are stored in host memory in a pseudo random order in 
accordance with the DV25 standard. 

[00385] A wide variety of FDCT mode selection algorithms, well-known in the 
art, that detect the presence of the emphasized horizontal edge patterns due to field 
interlacing may be used in the FDCT stage. An FDCT may be performed using any 
of the well known separable fast algorithms. Zigzag can be combined with the final 
transposition of the coefficients. Classification can be performed in a vector unit 
using a well known algorithm that selects a class based on maximum absolute value 
of the FDCT coefficients in the block. Modes and class indices are stored in the 
three least significant bits of the DC term. 

[00386] During the second stage, called Quantization stage, operation 4703 
transfers the reordered FDCT coefficients from the host memory (e.g., buffer 4712) 
to the local memory. After reformatting coefficients into a sign and magnitude 
format, determining macro block bit allocation and Quantization Number (QNO) 
values, scaling to produce Run-Level-Sign (RLS) coefficients, operation 4704 
transfers the QNO values and quantized RLS coefficients from the local memory 
back to the host memory (e.g., a buffer for QNO and Quantized RLS 4713). 
[00387] The reordered FDCT coefficients in two's complement format are 
converted to that in a sign and magnitude format so that the magnitudes and signs 
may be advantageously stored in two separate arrays. The processing of the signs 
and magnitudes in the VLC stage is uncoupled and can occur in parallel. Since the 
magnitude range of the DCT coefficients after class 3 initial scaling is from 0 to 255, 
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vector processing on magnitudes can be done using 16 byte-elements in parallel in a 
128-bit vector processor, as oppose to 8 short-elements. The magnitude data in a 
separate array is directly suitable as indices for looking up VLC code words and 
code word lengths from look up tables. 

[00388] The process of bit allocation determines the quatization number (QNO) 
used for compressing a DV segment. A DV segment contains 5 macro blocks. The 
amount of space used by each macro block within the segment varies with the 
complexity of the macro blocks. Any well known algorithm may be used to 
determine the quatization number (QNO). 

[00389] During the third and final stage, called the Entropy Coding stage, 
operation 4705 transfers the QNO values and the quantized RLS coefficients from 
the host memory (e.g., buffer 4713) to the local memory. Variable Length Coding 
(VLC) is performed to convert Run-Level-Sign coefficients computed in the 
previous stage to variable length code words, which are distributed in fixed length 
segments. After performing variable length coding, operation 4706 transferred the 
compressed video stream from the local memory back to host memory (e.g., a buffer 
for compressed video 4714). 

[00390] To encode a standard D V bit stream, The bandwidth required for 
operation 4701 to transfer pixel data is about 15.5 Mb/s; the bandwidth required to 
transfer reordered FDCT coefficients (e.g., operation 4702 or 4703) is about 31 
Mb/s; the bandwidth required to transfer QNO and Quantized RLS (e.g., operation 
4704 or 4705) is about 31 Mb/s; and the bandwidth required to transfer compressed 
video (e.g., operation 4705) is about 3.3 Mb/s. Thus, the overall bandwidth required 
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to perform a three-stage encoding operation is about 143 Mb/s. Such multiple-stage 
approach utilized the memory access bandwidth to reduce the required amount of 
local memory for data and the required amount of instruction cache on a processing 
engine. 

[00391] Figure 95 shows a memory management scheme for a method to transfer 
data in a Forward Discrete Cosine Transformation stage. Pixel data and FDCT 
coefficients are double buffered on local memory so that the transferring data 
between the local memory and the host memory can be performed in parallel with 
the computation performed in the FDCT stage. For example, while operation 4731 
accessing pixel buffer 4721 in order to perform the FDCT stage computation (e.g., 
mode selection, FDCT, initial scaling, and Macro Block (MB) reordering) on block 
n to generate FDCT coefficients on FDCT buffer 4723, DMA 0 transfers pixel block 
n+1 from the host memory to pixel buffer 4722 in operation 4733 and DMA 1 
transfers FDCT coefficients from FDCT buffer 4724 for block n-1 to the host 
memory in operation 4734. While operation 4735 accessing pixel buffer 4722 to 
generate FDCT coefficients for block n+1 on FDCT buffer 4724, DMA 0 transfers 
pixel block n+2 from the host memory to pixel buffer 4721 in operation 4737 and 
DMA 1 transfers FDCT coefficients from FDCT buffer 4723 for block n to the host 
memory in operation 4738. 

[00392] In one embodiment for encoding a DV video stream, the input DMA 
granularity is a 64x16 pixel block. The blocks are fetched in a raster scan order. The 
output DMA is macro block based. 4:1:1 macro blocks of 16 bit coefficients are 
stored sequentially in a DV25 pseudo random pattern. 
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[00393] Figure 96 shows a memory management scheme for a method to transfer 
data in a Quantization stage. Buffers 4741 - 4745 are allocated from the local 
memory of a process engine. DMA 0 transfers FDCT coefficients from the host 
memory to FDCT buffer 4741 on the local memory of a processing engine in 
operation 4749. Operation 4751 reads the FDCT coefficients from buffer 4741 in 
order to convert the coefficients from a two's complement format to a sign 
magnitude (SM) format. The SM coefficients are stored in SM buffer 4742 in 
operation 4752. After the coefficients in buffer 4741 are converted into SM format, 
DMA 0 loads next FDCT coefficients into buffer 4741 in operation 4755. Bit 
Allocation (BA) reads the SM coefficients in operation 4753 and generates 
Quantization Numbers (QNO) in buffer 4744 in operation 4754. Finally, the Scaling, 
and Run Level Sign Formatting (SRLSF) is performed using the QNO and SM 
coefficients to generate Run-Level-Sign (RLS) coefficients in RLS buffers 4745 and 
4746. Operations 4756 and 4757 read SM coefficients and QNO in order to generate 
RLS coefficients. RLS coefficients are double buffered in buffers 4745 and 4746 so 
that one RLS buffer is used in generating RLS coefficients while the RLS 
coefficients in the other RLS buffer may be concurrently transferred to the host 
memory. For example, after SRLSF operation 4761 saves the RLS coefficients in 
buffer 4745, DMA 2 transfers the RLS coefficients in buffer 4745 to the host 
memory in operation 4763, while SRLSF operation 4762 continues to stores the 
generated RLS coefficients into buffer 4745. Operations 4765 and 4764 operate in 
parallel using buffers 4745 and 4746 respectively. Similarly, operations 4767 and 
4766 operation in parallel. Operation 4768 continues in parallel with operations 
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4771 and 4772 for converting FDCT coefficients into SM coefficients, since DMA 0 
has already loaded the FDCT coefficients in operation 4755. Since FDCT buffer is 
retired at the early stage of the processing, the next DMA operation can be started 
right after the SM conversion to use the same buffer (e.g., operation 4755 starts right 
after operation 4751). The DMA operation 4755 can continue in parallel with the 
time consuming operation for bit allocation. Operations 4771 - 4788 repeats the 
operations 4751 - 4768 to process the next FDCT coefficients. 
[00394] In one embodiment, the input DMA 0 reads 5 768-byte macro blocks 
(e.g., 30 blocks) a time to fill the FDCT buffer 4741. QNO buffer is large enough to 
hold all QNO data for an entire frame, so that the QNO data is transferred to the host 
memory one frame at a time. A RLS buffer (4745 or 4746) can hold RLS data for 2 
blocks. Thus, 14 parallel SRLSF and DMA operations as those in operations 4763 
and 4762 (or, 4765 and 4764) may be used to generate and transfer RLS coefficients, 
before finally a DMA operation (e.g., 4768) is used to transfer the last two blocks of 
RLS to the host memory. 

[00395] Figure 97 shows a memory management scheme for a method to transfer 
data in an Entropy Coding stage. Compressed video generated by entropy coding is 
double buffered (e.g., VLC buffers 4801 and 4802) on local memory so that one of 
buffers is used in generating a portion of compressed video while another portion of 
the compressed video, which has been already generated on the other buffer, is 
transferred to the host memory. For example, while compressed video is generated 
on VLC buffer 4801 in operation 4811, DMA 0 transfers compressed video from 
VLC buffer 4802 to the host memory in operation 4813. 
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[00396] In one embodiment of the present invention, an array of QNO values for 
a frame is initially loaded into a buffer using a DMA channel. The QNO data is used 
in subsequent Variable Length Coding of RLS coefficients. RLS buffers 4803 - 4807 
are allocated from the local memory to store the RLS coefficients. After operation 

4881 loads RLS coefficients for a first macro block into buffer 4803, operation 4831 
performs pass 1 and pass 2 VLC packing on the first macro block, while operation 

4882 continues to load the second macro block into buffer 4804. Similarly, 
operations 4832 - 4834 performs pass 1 and pass 2 VLC packing on the RLS 
coefficients in buffers 4804 - 4806, while DMA 1 load buffers 4805 - 4807 with 
RLS coefficients in operations 4883 - 4885 respectively. Finally, operation 4835 
performs the pass 1 and pass 2 operations on the RLS coefficients in buffer 4807; 
and pass 3 distributes the remaining data within the segment in operations 4861 - 
4865. 

[00397] In the Entropy Code stage, when run is less than 16 and level is less than 
32, a look up table that contains 32-bit code words is used to convert RLS 
coefficients to code word; otherwise the coefficients is formatted into escaped data. 
The concatenated codes are stored with 16-bit write instructions since the block 
boundaries are 16 bit aligned. Incomplete Code word Structures (ICS) are used for 
book-keeping the information of remaining of blocks that can not be fitted in the 
corresponding blocks in a compressed segment; and Remaining Data Structures 
(RDS) are used to book keep the available spaces in the blocks for the distribution of 
remaining of blocks in pass 2 and pass 3 operation. 
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[00398] In pass 1 distribution, when the total length of a block of codes exceeds 
the corresponding fixed size block of storage space in the segment, an Incomplete 
Code Word Structure (ICS) is created to remember the incomplete codeword, its 
length and the location in the RLS buffer so that variable length coding and 
distribution can be continued from that point in pass 2 and pass 3 operations. Note 
that a code word can be up to 29 bits in length. An Incomplete Code Word Structure 
contains: 

[00399] 1) incomplete code word (e.g., 4 bytes), which is the first code word in 
the block that has not been completely distributed in the pass 1 or pass 2 operation; 
[00400] 2) incomplete code word length (e.g., 1 byte), which is the bit length of 
the incomplete code word that needs to be distributed; 
[00401] 3) EOB flag (e.g., 1 byte), which is set when all the RLS triplets in 
current block have been coded; 

[00402] 4) incomplete code word done flag (e.g., 1 byte), which is set after the 
last incomplete code word is distributed in a pass 2 or pass 3 operation; and 
[00403] 5) index in the RLS buffer (1 byte), which is the location in a RLS buffer 
where the remaining RLS triplets are stored. 

[00404] Note that the EOB flag may be set before the last incomplete code word 
is distributed. The incomplete code word done flag is always set after the EOB flag 
is set 

[00405] In pass 1 distribution, when the total length of codes for a block exceeds 
the corresponding fixed size block of storage space in the segment, a Remaining 
Data Structure (RDS) is created to contain the pointers to the empty space in the 
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block of storage space such that the empty space can be used in the pass 2 and pass 3 
operations to fill the remaining code words from other blocks. In one embodiment, a 
bit buffer is used to accumulate bits of code words to write concatenated code words 
16 bits a time. The content in the bit buffer is also stored in a RDS so that the code 
words to be distributed in pass 2 or pass 3 can be concatenated with the content in 
the bit buffer to fill the block of storage space. A Remaining Data Structure 
contains: 

[00406] 1) bit buffer bits (e.g., 2 bytes), which are the bits left in the bit buffer to 
be concatenated with other code words to fill the current block of storage space; 
[00407] 2) number of valid bits (e.g., 1 byte), which is the number of valid bits in 
bit buffer bits; 

[00408] 3) store address pointer (e.g., 2 bytes), which is the beginning address of 
an empty space in the current block of storage space to be filled up in pass 2 or pass 
3 operations; 

[00409] 4) end address pointer (e.g., 2 bytes), which is the ending address of the 
current block of storage space; and 

[00410] 5) buffer full flag (e.g., 1 byte), which is set when the current block of 
storage space is full (i.e., the store address pointer reaches the end address pointer). 
[00411] During pass2 and pass3 coding the list of Incomplete Code word 
Structures are scanned through to distribute the remaining code words in the unused 
space pointed by the list of Remaining Data Structure. In pass 2, the remaining of 
the blocks after the pass 1 operation that cannot be fitted into the corresponding 
compressed-data area are distributed in to their corresponding compressed macro 
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block. In pass 3, the remainder after the pass 2 operation is distributed into the same 
video segment. 

[00412] In the foregoing specification, the invention has been described with 
reference to specific exemplary embodiments thereof. It will be evident that various 
modifications may be made thereto without departing from the broader spirit and 
scope of the invention as set forth in the following claims. The specification and 
drawings are, accordingly, to be regarded in an illustrative sense rather than a 
restrictive sense. 
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